home *** CD-ROM | disk | FTP | other *** search
/ Halting the Hacker - A P…uide to Computer Security / Halting the Hacker - A Practical Guide to Computer Security.iso / rfc / rfc1768.txt < prev    next >
Text File  |  1997-04-01  |  111KB  |  2,524 lines

  1.  
  2.  
  3.  
  4.  
  5.  
  6.  
  7. Network Working Group                                          D. Marlow
  8. Request for Comments: 1768                                       NSWC-DD
  9. Category: Experimental                                        March 1995
  10.  
  11.  
  12.               Host Group Extensions for CLNP Multicasting
  13.  
  14. Status of this Memo
  15.  
  16.    This memo defines an Experimental Protocol for the Internet
  17.    community.  This memo does not specify an Internet standard of any
  18.    kind.  Discussion and suggestions for improvement are requested.
  19.    Distribution of this memo is unlimited.
  20.  
  21. Abstract
  22.  
  23.    This memo documents work performed in the TUBA (TCP/UDP over Bigger
  24.    Addresses) working group of IPng area prior to the July 1994 decision
  25.    to utilize SIPP-16 as the basis for IPng.  The TUBA group worked on
  26.    extending the Internet Protocol suite by the use of ISO 8473 (CLNP)
  27.    and its related routing protocols.  This memo describes multicast
  28.    extensions to CLNP and its related routing protocols for Internet
  29.    multicast use.  Publication of this memo does not imply acceptance by
  30.    any IETF Working Group for the ideas expressed within.
  31.  
  32.    This memo provides a specification for multicast extensions to the
  33.    CLNP protocol similar to those provided to IP by RFC1112.  These
  34.    extensions are intended to provide the mechanisms needed by a host
  35.    for multicasting in a CLNP based Internet.  This memo covers
  36.    addressing extensions to the CLNP addressing structure, extensions to
  37.    the CLNP protocol and extensions to the ES-IS protocol.  An appendix
  38.    discusses the differences between IP multicast and the CLNP multicast
  39.    approach provided in this memo.
  40.  
  41. Acknowledgments
  42.  
  43.    The specification provided here was developed by a number of
  44.    individuals in the IETF TUBA working group as well as the ANSI X3S3.3
  45.    and ISO SC6 WG2 committees.  Key contributions were made by Steve
  46.    Deering, Joel Halpern, Dave Katz and Dave Oran.
  47.  
  48.  
  49.  
  50.  
  51.  
  52.  
  53.  
  54.  
  55.  
  56.  
  57.  
  58. Marlow                                                          [Page 1]
  59.  
  60. RFC 1768                   CLNP Multicasting                  March 1995
  61.  
  62.  
  63. Table of Contents
  64.  
  65.    1.  Introduction ..........................................  2
  66.    2.  Levels of Conformance..................................  3
  67.    3.  Group Network Addresses................................  4
  68.    4.  Model of a CLNP End System Multicast Implementation....  8
  69.    5.  Extensions to the CLNP Protocol........................  8
  70.    6.  Extensions to the ES-IS Routeing Protocol ............. 15
  71.    7.  Security Considerations ............................... 39
  72.    Appendix A.  Differences with RFC 1112 .................... 40
  73.    Appendix B.  Issues Under Study ........................... 43
  74.    References ................................................ 44
  75.    Author's Address .......................................... 45
  76.  
  77. 1.      Introduction
  78.  
  79.    This memo provides a specification for multicast extensions for CLNP
  80.    in order to provide a CLNP based Internet the capabilities provided
  81.    for IP by RFC 1112 (Host Extensions for IP Multicasting) [RFC1112].
  82.    This memo uses an outline similar to that of RFC 1112.
  83.  
  84.    Paraphrasing RFC 1112, "CLNP multicasting is the transmission of a
  85.    CLNP datagram to a "host group", a set of zero or more End Systems
  86.    identified by a single group Network address (GNA). A multicast
  87.    datagram is delivered to all members of its destination host group
  88.    with the same "best-efforts" reliability as regular unicast CLNP
  89.    datagrams, i.e., the datagram is not guaranteed to arrive intact at
  90.    all members of the destination group or in the same order relative to
  91.    other datagrams.
  92.  
  93.    "The membership of a host group is dynamic; that is End Systems may
  94.    join and leave groups at any time. There is no restrictions on the
  95.    location or number of members in a host group. An End System may be a
  96.    member of more than one group at a time. An End System need not be a
  97.    member of a group to send datagrams to it.
  98.  
  99.    "A host group may be permanent or transient. A permanent group has an
  100.    administratively assigned GNA. It is the address, not the membership
  101.    of the group, that is permanent; at any time a permanent group may
  102.    have any number of members, even zero.
  103.  
  104.    "Internetwork forwarding of CLNP multicast datagrams is handled by
  105.    "multicast capable" Intermediate Systems which may be co-resident
  106.    with unicast capable Intermediate Systems.
  107.  
  108.    The multicast extensions to the CLNP addressing structure defines
  109.    group Network addresses which identify host groups.  The multicast
  110.    extensions to CLNP provides a means for identifying a CLNP packet and
  111.  
  112.  
  113.  
  114. Marlow                                                          [Page 2]
  115.  
  116. RFC 1768                   CLNP Multicasting                  March 1995
  117.  
  118.  
  119.    provides scope control mechanisms for CLNP multicast packets. The
  120.    multicast extensions to the ES-IS protocol provide the mechanisms
  121.    needed for a host to exchange control information with multicast
  122.    capable routers.  These extensions to the ES-IS protocol provide for
  123.    a host to "announce" which multicast packets are of interest and for
  124.    a multicast capable router to dynamically "map" group Network
  125.    addresses to subnetwork addresses.
  126.  
  127.    This memo specifies the extensions required by an End System to make
  128.    use of CLNP multicast. In addition the requirements placed upon
  129.    multicast capable Intermediate Systems to exchange information with
  130.    multicast capable End Systems is specified. No specifications are
  131.    provided related to the information exchanges between Intermediate
  132.    Systems to support multicast route selection or multicast Protocol
  133.    Data Unit (PDU) forwarding. A discussion of multicast route selection
  134.    and PDU forwarding has been written by Steve Deering [Deering91].
  135.    Note that for these multicast extensions to work there must exist an
  136.    uninterrupted path of multicast capable routers between the End
  137.    Systems comprising a host group (such paths may utilize tunneling
  138.    (i.e., unicast CLNP encapsulated paths between multicast capable CLNP
  139.    routers)).   In order to support multicast route selection and
  140.    forwarding for a CLNP based internet additional specifications are
  141.    needed. Specifications of this type could come in the form of new
  142.    protocols, extensions to the current CLNP based routing protocols or
  143.    use of a technique out of the IETF's Inter-Domain Multicast Routing
  144.    (IDMR) group. The IDMR group is currently investigating multicast
  145.    protocols for routers which utilize a router's unicast routing
  146.    protocols, this approach may extend directly to CLNP routers.
  147.  
  148.    While many of the techniques and assumptions of IP multicasting (as
  149.    discussed in RFC 1112) are used in CLNP multicasting, there are
  150.    number of differences. Appendix A describes the differences between
  151.    CLNP multicasting and IP multicasting. This memo describes techniques
  152.    brought in directly from projects within ISO to incorporate multicast
  153.    transmission capabilities into CLNP [MULT-AMDS].
  154.  
  155. 2.      Levels of Conformance
  156.  
  157.    There are three levels of conformance for End Systems to this
  158.    specification:
  159.  
  160.    Level 0: no support for CLNP multicasting.
  161.  
  162.    There is no requirement for a CLNP End System (or Intermediate
  163.    System) to support CLNP multicasting. Level 0 hosts should be
  164.    unaffected by the presence of multicast activity. The destination
  165.    addresses used in support of multicast transfers, the GNA, should not
  166.    be enabled by a non-multicast capable End System and the PDUs
  167.  
  168.  
  169.  
  170. Marlow                                                          [Page 3]
  171.  
  172. RFC 1768                   CLNP Multicasting                  March 1995
  173.  
  174.  
  175.    themselves are marked differently than unicast PDUs and thus should
  176.    be quietly discarded.
  177.  
  178.    Level 1: support for sending but not receiving CLNP multicast PDUs.
  179.  
  180.    An End System originating multicast PDUs is required to know whether
  181.    a multicast capable Intermediate System is attached to the
  182.    subnetwork(s) that it originates multicast PDUs (i.e., to determine
  183.    the destination SNPA (subnet) address). An End System with Level 1
  184.    conformance is required to implement all parts of this specification
  185.    except for those supporting only Multicast Announcement.  An End
  186.    System is not required to know the current Multicast Address Mapping
  187.    to start originating multicast PDUs.
  188.  
  189.    Note: It is possible for End System not implementing Multicast
  190.    Address Mapping to successfully originate multicast PDUs (but with
  191.    the End System knowing of the existence of a multicast capable
  192.    Intermediate System). Such operation may lead to inefficient
  193.    subnetworks use.  Thus when an End System continues (or may continue)
  194.    to originate multicast PDUs destined for the same group,
  195.    implementations are to provide Multicast Address Mapping support.
  196.  
  197.    Level 2: full support for CLNP multicasting.
  198.  
  199.    Level 2 allows a host to join and leave host groups as well as send
  200.    CLNP PDUs to host groups. It requires implementation by the End
  201.    System of all parts of this specification.
  202.  
  203. 3.      Group Network Addresses
  204.  
  205.    Individual Network addresses used by CLNP for End System addressing
  206.    are called Network Service Access Points (NSAPs). RFC 1237 defines
  207.    the NSAP address for use in the Internet. In order to provide an
  208.    address for a group of End Systems, this specification does not
  209.    change the definition of the NSAP address, but adds a new type of
  210.    identifier - the group Network address - that supports a multicast
  211.    Network service (i.e., between a single source NSAP, identified by an
  212.    individual Network address, and a group of destination NSAPs,
  213.    identified by a group Network address). Host groups are identified by
  214.    group Network addresses.
  215.  
  216.    In the development of multicast address extensions to CLNP,
  217.    requirements were identified for: (1)"easily distinguishing" group
  218.    addresses at the Network layer from NSAP addresses; (2)leaving the
  219.    currently allocated address families unaffected and (3)ensuring that
  220.    the approach taken would not require the establishment of new
  221.    addressing authorities. In addition, it was agreed that providing
  222.    multicast options for all OSI Network layer users was desirable and
  223.  
  224.  
  225.  
  226. Marlow                                                          [Page 4]
  227.  
  228. RFC 1768                   CLNP Multicasting                  March 1995
  229.  
  230.  
  231.    thus the group Network addressing solution should support options for
  232.    all address formats covered by ISO/IEC 8348 | CCITT Recommendation
  233.    X.213. The only viable means identified for meeting all requirements
  234.    was via creating a new set of AFI values with a fixed one-to-one
  235.    mapping between each of the existing AFI values and a corresponding
  236.    group AFI value.
  237.  
  238.    Group Network addresses are defined by creating a new set of AFI
  239.    values, one for each existing AFI value, and a fixed one-to-one
  240.    mapping between each of the existing AFI values and a corresponding
  241.    group AFI value. The syntax of a group Network address is identical
  242.    to the syntax of an individual Network address, except that the value
  243.    of the AFI in an individual Network address may be only one of the
  244.    values already allocated for individual Network addresses, whereas
  245.    the value of the AFI in a group Network address may be only one of
  246.    the values allocated here for group Network addresses. The AFI values
  247.    allocated for group Network addresses have been chosen in such a way
  248.    that they do not overlap, in the preferred encoding defined by
  249.    ISO/IEC 8348 | CCITT Recommendation X.213, with any of the AFI values
  250.    that have already been allocated for individual Network addresses.
  251.  
  252. 3.1     Definitions
  253.  
  254.    group Network address: an address that identifies a set of zero or
  255.    more Network service access points; these may belong to multiple
  256.    Network entities, in different End Systems.
  257.  
  258.    individual Network address: an address that identifies a single NSAP.
  259.  
  260. 3.2     CLNP Addresses
  261.  
  262.    A discussion of the CLNP address format is contained in RFC 1237. The
  263.    structure of all CLNP addresses is divided into two parts the Initial
  264.    Domain Part (IDP) and the Domain Specific Part (DSP). The first two
  265.    octets of the IDP are the Authority and Format Identifier (AFI)
  266.    field. The AFI has an abstract syntax of two hexadecimal digits with
  267.    a value in the range of 00 to FF. In addition to identifying the
  268.    address authority responsible for allocating a particular address and
  269.    the format of the address, the AFI also identifies whether an address
  270.    is an individual Network address or a group Network address. There
  271.    are 90 possible AFI values to support individual Network address
  272.    allocations. In addition, when the AFI value starts with the value
  273.    "0" this identifies that the field contains an incomplete individual
  274.    Network address (i.e., identifies an escape code).
  275.  
  276.    Table 1 allocates 90 possible AFI values to support group Network
  277.    address allocations. In addition if the first two digits of the IDP
  278.    are hexadecimal FF, this indicates the presence of an incomplete
  279.  
  280.  
  281.  
  282. Marlow                                                          [Page 5]
  283.  
  284. RFC 1768                   CLNP Multicasting                  March 1995
  285.  
  286.  
  287.    group Network address. The allocation of group addresses is
  288.    restricted to be only from the AFI values allocated for the
  289.    assignment of group addresses in Table 1. An addressing authority in
  290.    allocating either Network addresses or authorizing one or more
  291.    authorities to allocate addresses, allocates both individual and the
  292.    corresponding group addresses. Thus each block of addresses allocated
  293.    by an addressing authority (or its sub-authority) contains a block of
  294.    individual Network addresses and group Network addresses.  The
  295.    individual and group address block allocated are differentiated by
  296.    the AFI values used which are related as shown in Table 1.
  297.  
  298.    Group Network addresses are only used as the destination address
  299.    parameter of a CLNP PDU. Source Address parameters are never
  300.    permitted to be group Network addresses.
  301.  
  302.    Table 2 lists the AFI values which have not been assigned, at this
  303.    time, for the support of neither individual nor group address
  304.    allocation. Future assignment of these AFI values is possible.
  305.    Additional information concerning individual Network addresses (i.e.,
  306.    NSAP and NET (Network Entity Titles)) is contained in RFC 1237.
  307.  
  308.    Note: While the format of the Initial Domain Part of a group Network
  309.    address is assigned, the format for the Domain Specific Part of the
  310.    group Network address is specified by an addressing authority and is
  311.    out of the scope of this memo.  While NSAP address assignments are
  312.    typically made to support hierarchical unicast routing, a similar
  313.    consideration for group Network address assignments may not exist.
  314.  
  315.  
  316.  
  317.  
  318.  
  319.  
  320.  
  321.  
  322.  
  323.  
  324.  
  325.  
  326.  
  327.  
  328.  
  329.  
  330.  
  331.  
  332.  
  333.  
  334.  
  335.  
  336.  
  337.  
  338. Marlow                                                          [Page 6]
  339.  
  340. RFC 1768                   CLNP Multicasting                  March 1995
  341.  
  342.  
  343.          TABLE 1 - Relationship of AFI Individual and Group Values
  344.         -----------------------------------------------------------
  345.         |Individual  Group | Individual  Group | Individual Group |
  346.         -----------------------------------------------------------
  347.         | 0x           FF  |                   |                  |
  348.         | 10           A0  |     40        BE  |     70       DC  |
  349.         | 11           A1  |     41        BF  |     71       DD  |
  350.         | 12           A2  |     42        C0  |     72       DE  |
  351.         | 13           A3  |     43        C1  |     73       DF  |
  352.         | 14           A4  |     44        C2  |     74       E0  |
  353.         | 15           A5  |     45        C3  |     75       E1  |
  354.         | 16           A6  |     46        C4  |     76       E2  |
  355.         | 17           A7  |     47        C5  |     77       E3  |
  356.         | 18           A8  |     48        C6  |     78       E4  |
  357.         | 19           A9  |     49        C7  |     79       E5  |
  358.         | 20           AA  |     50        C8  |     80       E6  |
  359.         | 21           AB  |     51        C9  |     81       E7  |
  360.         | 22           AC  |     52        CA  |     82       E8  |
  361.         | 23           AD  |     53        CB  |     83       E9  |
  362.         | 24           AE  |     54        CC  |     84       EA  |
  363.         | 25           AF  |     55        CD  |     85       EB  |
  364.         | 26           B0  |     56        CE  |     86       EC  |
  365.         | 27           B1  |     57        CF  |     87       ED  |
  366.         | 28           B2  |     58        D0  |     88       EE  |
  367.         | 29           B3  |     59        D1  |     89       EF  |
  368.         | 30           B4  |     60        D2  |     90       F0  |
  369.         | 31           B5  |     61        D3  |     91       F1  |
  370.         | 32           B6  |     62        D4  |     92       F2  |
  371.         | 33           B7  |     63        D5  |     93       F3  |
  372.         | 34           B8  |     64        D6  |     94       F4  |
  373.         | 35           B9  |     65        D7  |     95       F5  |
  374.         | 36           BA  |     66        D8  |     96       F6  |
  375.         | 37           BB  |     67        D9  |     97       F7  |
  376.         | 38           BC  |     68        DA  |     98       F8  |
  377.         | 39           BD  |     69        DB  |     99       F9  |
  378.         -----------------------------------------------------------
  379.  
  380.  
  381.  
  382.  
  383.  
  384.  
  385.  
  386.  
  387.  
  388.  
  389.  
  390.  
  391.  
  392.  
  393.  
  394. Marlow                                                          [Page 7]
  395.  
  396. RFC 1768                   CLNP Multicasting                  March 1995
  397.  
  398.  
  399.             TABLE 2 - AFI values reserved for future allocation
  400.  
  401.                               --------------
  402.                               |    1A-1F   |
  403.                               |    2A-2F   |
  404.                               |    3A-3F   |
  405.                               |    4A-4F   |
  406.                               |    5A-5F   |
  407.                               |    6A-6F   |
  408.                               |    7A-7F   |
  409.                               |    8A-8F   |
  410.                               |    9A-9F   |
  411.                               |    FA-FE   |
  412.                               --------------
  413.  
  414. 4.      Model of a CLNP End System Multicast Implementation
  415.  
  416.    The use of multicast transmission by a CLNP End System involves
  417.    extensions to two protocols: CLNP and the ES-IS Routeing Protocol. To
  418.    provide level 0 service (no support for CLNP multicast), no
  419.    extensions to these two protocols are required. To provide level 1
  420.    service (support for sending but not receiving CLNP multicast PDUs)
  421.    all extensions contained in the following sections are required
  422.    except for those supporting only Multicast Announcement.  In order to
  423.    support level 2 service (full support for CLNP multicasting), the
  424.    extensions contained in the following sections are required.
  425.    Extensions identified for Intermediate Systems are not required (or
  426.    appropriate) for End Systems. Multicast transmission also requires
  427.    the use of a group Network address (as previously described) as the
  428.    destination address parameter.
  429.  
  430. 5.      Extensions to the CLNP protocol
  431.  
  432.    This section provides extensions to the CLNP Protocol [CLNP] ISO
  433.    8473-1, to support multicast transmission. These additions provide
  434.    procedures for the connectionless transmission of data and control
  435.    information from one network-entity to one or more peer network-
  436.    entities.
  437.  
  438.    In developing the multicast extensions for CLNP a decision was needed
  439.    on how to "mark" a packet as multicast (versus the current unicast
  440.    packets).  Such marking is necessary since the forwarding behavior
  441.    for multicast packets is different (e.g., multiple copies of a packet
  442.    may need to be forwarded).  The two alternatives considered were to
  443.    mark the packet (via a particular field) or to mark the destination
  444.    address, in the end both were done.  The destination address for a
  445.    multicast PDU identifies a host group which is of a very different
  446.    nature  than the unicast NSAP address.  Rather than changing the
  447.  
  448.  
  449.  
  450. Marlow                                                          [Page 8]
  451.  
  452. RFC 1768                   CLNP Multicasting                  March 1995
  453.  
  454.  
  455.    nature of NSAP addresses, a new set of addresses were created named
  456.    group Network addresses which are marked within the first octet
  457.    (i.e., the AFI field) with values reserved for group Network
  458.    addresses.
  459.  
  460.    Consideration was given to no further marking of the PDU; however, a
  461.    problem was identified with only using the group Network address to
  462.    identify multicast packets.  Currently routers implementing the IS-IS
  463.    Intra-Domain protocol as Level 1 routers when receiving a packet with
  464.    an unknown destination address are permitted to either discard the
  465.    packet or send it to a Level 2 router.  Such actions by non-multicast
  466.    capable routers to multicast packets can lead to non-deterministic
  467.    behavior.  Level 1 routers upon receiving a packet containing a group
  468.    Network address might pass the packet up to a Level 2 router (which
  469.    may or may not be multicast capable) or it might discard it.
  470.    Depending upon the circumstances this might lead to whole regions
  471.    missing packets or packet duplication (possibly even explosion).  The
  472.    result was to seek deterministic behavior by non-multicast capable
  473.    routers by creating a new PDU type (Multicast Data PDU) and inserting
  474.    into the CLNP reasons for discard: receiving a PDU of unknown type.
  475.    Note that this reason for discard is mandatory on multicast capable
  476.    and non-multicast capable CLNP implementations.
  477.  
  478. 5.1     Definitions
  479.  
  480.    multicast: Data transmission to one or more destinations in a
  481.    selected group in a single service invocation.
  482.  
  483.    multicast capable Intermediate System: An Intermediate System which
  484.    incorporates the multicast features of the Network layer.
  485.  
  486. 5.2     Addresses
  487.  
  488.    The destination address parameter of a multicast PDU shall contain a
  489.    group Network address. The source address parameter shall be an
  490.    individual Network address.
  491.  
  492. 5.3     Extensions to the current protocol functions
  493.  
  494.    In order to support multicast transmissions the following optional
  495.    CLNP protocol functions will be implemented:
  496.  
  497. 5.3.1   Header Format Analysis function
  498.  
  499.    The header format analysis function optionally provides capabilities
  500.    to Network entities which support multicast transfer to supply
  501.    applicable PDUs directly to End Systems served by such a Network
  502.    entity as well as to forward such PDUs on to other Network entities.
  503.  
  504.  
  505.  
  506. Marlow                                                          [Page 9]
  507.  
  508. RFC 1768                   CLNP Multicasting                  March 1995
  509.  
  510.  
  511.    This optional functionality is realized through a Network entity with
  512.    multicast capability identifying a PDU as using multicast transfer
  513.    via the PDU type and the PDU's destination address field.
  514.  
  515.    If a Network entity supports multicast transmission, then the header
  516.    format analysis function shall provide checking to ensure that a PDU
  517.    does not contain a group Network address in the source address field.
  518.    Any PDU header analyzed to have a group address in the source address
  519.    field shall be discarded.
  520.  
  521. 5.3.2   Route PDU function
  522.  
  523.    The route PDU function optionally provides capabilities to Network
  524.    entities which support multicast transfer for determining multiple
  525.    Network entities to which a single PDU shall be forwarded to. This
  526.    may result in multiple invocations of the forward PDU function and
  527.    hence the need to make multiple copies of the PDU. For PDUs that are
  528.    received from a different Network entity, the optional functionality
  529.    for the route PDU function is realized as a result of the header
  530.    format analysis function's recognition of the PDU as being a
  531.    multicast PDU. A Network entity attached to more than one subnetwork
  532.    when originating a multicast PDU is permitted to originate the PDU on
  533.    more than one subnetwork.
  534.  
  535.    Note: The ES-IS function "Extensions to the ISO CLNP Route Function
  536.    by End Systems" discussed in section 6.10 identifies on which
  537.    subnetworks an End System attached to more than one subnetwork must
  538.    originate multicast PDUs on.
  539.  
  540.    Note: The purpose in allowing an originating Network entity to
  541.    originate a multicast PDU on multiple subnetworks is to support the
  542.    development of multicast IS-IS protocols which will need to determine
  543.    on which subnetworks a multicast PDU has visited.  This behavior is
  544.    predicated on the assumption that the Intermediate Systems in the OSI
  545.    environment performing multicast forwarding form a connected set.
  546.  
  547. 5.3.3   Forward PDU function
  548.  
  549.    This function issues an SN-UNITDATA request primitive, supplying the
  550.    subnetwork or Subnetwork Dependent Convergence Function (SNDCF)
  551.    identified by the route PDU function with the protocol data unit as
  552.    user data to be transmitted, the address information required by that
  553.    subnetwork or SNDCF to identify the "next" system or systems within
  554.    the subnetwork-specific addressing domain (this may be one or more
  555.    Intermediate Systems and/or one or more destination End Systems), and
  556.    quality of service constraints (if any) to be considered in the
  557.    processing of the user data.
  558.  
  559.  
  560.  
  561.  
  562. Marlow                                                         [Page 10]
  563.  
  564. RFC 1768                   CLNP Multicasting                  March 1995
  565.  
  566.  
  567. 5.3.4   Discard PDU function
  568.  
  569.    Add an additional reason for discard - a PDU is received with an
  570.    unknown type code.
  571.  
  572. 5.3.5   Error reporting function
  573.  
  574.    It is important to carefully control the use of the error reporting
  575.    capability in the case of multicast transfers.  The primary concern
  576.    is to avoid the occurrence of broadcast storms and thus a multicast
  577.    PDU may not cause the origination of another multicast PDU. This is
  578.    the primary reason that the source address is not permitted to be a
  579.    group address. In addition, a multicast PDU with error reporting
  580.    permitted can result in flooding the source network-entity (as well
  581.    as the networks used) with Error Report PDUs.
  582.  
  583.    While error reports are permitted on multicast PDUs, a PDU with a
  584.    group Network address in the source address field shall not be
  585.    responded to with an Error Report. This is to ensure that a multicast
  586.    PDU does not generate another multicast PDU. If the source address is
  587.    identified as a group address then an error report PDU shall not be
  588.    generated and the original PDU shall be discarded.
  589.  
  590. 5.3.6   Source routing functions
  591.  
  592.    No source routing capability is provided for multicast PDU transfer.
  593.    The NS provider shall not accept a multicast PDU with source route
  594.    parameters.
  595.  
  596. 5.4     Scope control function
  597.  
  598. 5.4.1   Overview
  599.  
  600.    The scope control function is an option for multicast PDU forwarding
  601.    only. The scope control function allows the originator to limit the
  602.    forwarding of the multicast PDU. The scope control function provides
  603.    the capability to limit the relaying of a particular PDU based on the
  604.    individual Network addressing hierarchy and/or limit the amount of
  605.    multicast expansion which can take place. In cases where both forms
  606.    of scope control are applied to the same PDU, forwarding will cease
  607.    once either has reached its scope control limit.
  608.  
  609. 5.4.2   Prefix Based Scope Control
  610.  
  611.    The prefix based scope control function allows the originator to
  612.    specify a specific set of address prefixes where the multicast
  613.    forwarding of a PDU by an Intermediate System occurs only if one of
  614.    the prefixes matches the Network Entity Title (NET) of the
  615.  
  616.  
  617.  
  618. Marlow                                                         [Page 11]
  619.  
  620. RFC 1768                   CLNP Multicasting                  March 1995
  621.  
  622.  
  623.    Intermediate System. Prefix based scope control may be selected only
  624.    by the originator of a PDU. Prefix based scope control is
  625.    accomplished using one or more address prefixes held in a parameter
  626.    within the options part of the PDU header. The length of this
  627.    parameter is determined by the originating network entity, and does
  628.    not change during the lifetime of a PDU.
  629.  
  630.    When an Intermediate System receives a multicast PDU containing a
  631.    prefix based scope control parameter, forwarding is only performed if
  632.    every octet of one of the prefixes contained in the prefix based
  633.    scope control parameter matches that Intermediate System's NET,
  634.    starting from the beginning of its NET. If no such prefix match
  635.    exists, the Intermediate System discards the PDU. The error reporting
  636.    function shall not be invoked upon PDU discard.
  637.  
  638. 5.4.3   Radius Scope Control
  639.  
  640.    The radius scope control function allows the originator to specify a
  641.    maximum logical distance where multicast expansion can occur. It is
  642.    closely associated with the header format analysis function. Each IS
  643.    receiving a multicast PDU which is capable of expanding and which
  644.    contains a Radius Scope Control parameter, decrements the Radius
  645.    Scope Control field in the PDU by an administratively set amount
  646.    between 0 and the maximum value of the field.  An IS, when it
  647.    decrements the Radius Scope Control field, shall place a value of 0
  648.    into this field if its current value is less than the amount it is to
  649.    decrement by.   This function determines whether the PDU received may
  650.    be forwarded or whether its Radius has been reached, in which case it
  651.    shall be discarded. An Intermediate System shall not forward a
  652.    multicast PDU containing a Radius Scope Control parameter with a
  653.    value of 0. The error reporting function shall not be invoked upon
  654.    PDU discard.
  655.  
  656. 5.4.3.1 Radius Scope Control Example
  657.  
  658.    The Radius Scope Control parameter is useful where policies have been
  659.    established across the potential forwarding path.  One possible
  660.    policy for Internet use is for multicast capable routers to treat
  661.    this field as a hop count within a domain (decrement by one unit) and
  662.    for inter-domain routers to either decrement this field to an even
  663.    multiple of 256 when crossing domains where prior agreements have
  664.    been made or decrement this field to 0 (i.e., discard the packet) for
  665.    other domains.
  666.  
  667.  
  668.  
  669.  
  670.  
  671.  
  672.  
  673.  
  674. Marlow                                                         [Page 12]
  675.  
  676. RFC 1768                   CLNP Multicasting                  March 1995
  677.  
  678.  
  679. 5.5     Structure and Encoding of PDUs
  680.  
  681.    Multicast transmission is accomplished via the transfer of Multicast
  682.    Data (MD) PDUs. The PDU type code for a MD PDU is "1 1 1 0 1". The
  683.    format of the MD PDU is identical to that of the Data (DT) PDU.   The
  684.    MD and DT PDU may contain the same optional parameters with the
  685.    following exceptions: (1)The source routing parameter is permitted
  686.    within DT PDUs but not MD PDUs; and (2)The scope control parameter is
  687.    permitted within MD PDUs but not DT PDUs.
  688.  
  689. 5.6     Optional parameters for multicast support
  690.  
  691. 5.6.1   Prefix Based Scope Control
  692.  
  693.    The prefix based scope control parameter specifies one or more
  694.    address prefixes for which Intermediate System forwarding requires a
  695.    match of one of the contained prefixes with the beginning of the
  696.    Intermediate System's NET.
  697.  
  698.    Parameter Code:         1100 0100
  699.  
  700.    Parameter Length:       variable
  701.  
  702.    Parameter Value:        a concatenation of address prefix entries
  703.  
  704.    The parameter value contains an address prefix list. The list
  705.    consists of variable length address prefix entries. The first octet
  706.    of each entry gives the length of the address prefix denominated in
  707.    bits that comprises the remainder of the entry.  If the length field
  708.    does not specify an integral number of octets then the prefix entry
  709.    is followed by enough trailing zeroes to make the end of the entry
  710.    fall on an octet boundary.  The list must contain at least one entry.
  711.  
  712.    The prefix shall end on a boundary that is legal in the abstract
  713.    syntax of the address family from which it is derived.  For example,
  714.    the encoding of a prefix whose DSP is expressed in decimal syntax
  715.    must end on a semi-octet boundary, while the encoding of a prefix
  716.    whose DSP is expressed in binary syntax can end on an arbitrary bit
  717.    boundary. If the end of the prefix falls within the IDP, then the
  718.    prefix must end on a semi-octet boundary and must not contain any
  719.    padding characters.
  720.  
  721.    Note: The length of the prefix based scope control parameter is
  722.    determined by the originator of the PDU and is not changed during the
  723.    lifetime of the PDU.
  724.  
  725.  
  726.  
  727.  
  728.  
  729.  
  730. Marlow                                                         [Page 13]
  731.  
  732. RFC 1768                   CLNP Multicasting                  March 1995
  733.  
  734.  
  735. 5.6.1.1 Prefix matching
  736.  
  737.    A prefix that extends into the DSP shall be compared directly against
  738.    the encoded NET address, including any padding characters that may be
  739.    present.  A prefix which does not extend into the DSP shall be
  740.    compared against the derived quantity NET', which is obtained from
  741.    the NET address by removing all padding characters (as defined by the
  742.    binary encoding process of ISO 8348).
  743.  
  744.    The existence of a match shall be determined as follows:
  745.  
  746.    a)   If the encoded NET (or NET') contains fewer bits than the pre-
  747.         fix, then there is no match.
  748.  
  749.    b)   If the encoded NET (or NET') contains at least as many bits as
  750.         the prefix, and all bits of the prefix are identical to the
  751.         corresponding leading bits of the encoded NET (or NET'), there
  752.         is a match.  Otherwise, there is no match.
  753.  
  754. 5.6.2   Radius Scope Control
  755.  
  756.    The radius scope control parameter specifies the logical distance
  757.    that a multicast PDU can be forwarded.
  758.  
  759.    Parameter Code:         1100 0110
  760.  
  761.    Parameter Length:       two octets
  762.  
  763.    Parameter Value:        two octets which represents the remaining
  764.                            distance, that the PDU can be forwarded,
  765.                            in administratively set units.
  766.  
  767. 5.7     Provision of the Underlying Service
  768.  
  769.    For a subnetwork that provides an inherent multicast capability, it
  770.    is the functionality of the SNDCF to provide the mapping between
  771.    group Network addresses and the corresponding addressing capability
  772.    of the subnetwork.
  773.  
  774. 5.8      Conformance
  775.  
  776.    All of the extensions provided to the functions to support multicast
  777.    capability are optional. For an End System or Intermediate System
  778.    which is not multicast capable these extensions are not applicable.
  779.    An implementation claiming conformance as a multicast capable End
  780.    System shall meet all of the requirements for an End System which is
  781.    not multicast capable and also provide all of the multicast
  782.    extensions provided here. An implementation claiming conformance as a
  783.  
  784.  
  785.  
  786. Marlow                                                         [Page 14]
  787.  
  788. RFC 1768                   CLNP Multicasting                  March 1995
  789.  
  790.  
  791.    multicast capable Intermediate System shall meet all of the
  792.    requirements for an Intermediate System which is not multicast
  793.    capable and also provide all of the multicast extensions provided
  794.    here.
  795.  
  796. 6.      Extensions to the ES-IS Routeing Protocol
  797.  
  798.    This section provides optional extensions to the ES-IS Routeing
  799.    Protocol [ES-IS], ISO 9542 to support the transfer of multicast PDUs.
  800.    It is an explicit goal of this specification that ESs and ISs, some
  801.    of which will have multicast capabilities and some without, will be
  802.    able to fully function on the same subnetworks. This specification
  803.    does not change any aspect of a currently defined (i.e., non-
  804.    multicast) ISO 9542 implementation, it adds new optional
  805.    functionality not modifying current functionality. Two basic
  806.    functions are provided: multicast announcement and multicast address
  807.    mapping.
  808.  
  809. 6.1     Overview of the protocol
  810.  
  811. 6.1.1   Operation of ESs receiving multicast PDUs
  812.  
  813.    ESs, upon initialization and periodically thereafter, will construct
  814.    End System Group Hello (ESGH) PDUs identifying, by particular group
  815.    Network addresses, the multicast PDUs it wishes to receive. The ES
  816.    will periodically originate (announce) these ESGH PDUs on the
  817.    subnetwork it wishes to receive these on. Reporting the same group
  818.    Network address on multiple subnetworks may result in the reception
  819.    of duplicate PDUs. ES-IS operations related to requesting the same
  820.    group Network address on multiple subnetworks are handled totally
  821.    independently (e.g., using different logical timers,...). It is
  822.    permitted for an ES to report a number of group Network addresses in
  823.    the same ESGH PDU.  The only restrictions placed on providing
  824.    multiple group Network addresses within the same ESGH PDU are that
  825.    all packets requested are to be received on the same subnet, with the
  826.    same holding time and that the ESGH PDU be of length equal to or less
  827.    that its maximum packet size constraint.  Note that each group
  828.    Network address in the ESGH PDU is paired with its own SNPA
  829.    (subnetwork point of attachment) address.
  830.  
  831.    An ES will always have an SNPA address associated with each of its
  832.    active group Network addresses. An SNPA address is a subnetwork
  833.    address, in the case of a subnetwork which uses IEEE 802 addresses
  834.    the SNPA address is a 48 bit IEEE 802 MAC (media access control)
  835.    address.  Of particular interest is the address used to mark the
  836.    destination group.  For a subnetwork using IEEE 802 addressing a
  837.    group SNPA address uses a particular bit position to "mark" group
  838.    SNPA addresses.
  839.  
  840.  
  841.  
  842. Marlow                                                         [Page 15]
  843.  
  844. RFC 1768                   CLNP Multicasting                  March 1995
  845.  
  846.  
  847.    Upon initialization the ES may have static SNPA address associations
  848.    (Pre-configured SNPA addresses). For any group Network address
  849.    without a Pre-configured SNPA address that the ES wishes to receive,
  850.    the ES will associate the "All Multicast Capable End Systems" SNPA
  851.    address.  Upon receiving a Multicast Address Mapping (MAM) PDU
  852.    containing a group Network address that the ES is announcing, the ES
  853.    will use the SNPA address pairing contained in the MAM PDU for that
  854.    group Network address. Upon the expiration of the Mapping Holding
  855.    Timer, the ES shall revert back to associating either the Pre-
  856.    configured SNPA address if one exists or the "All Multicast Capable
  857.    End Systems" SNPA address for the specific group Network address.
  858.    While an ES is permitted to listen in on other ESs announcements
  859.    (needed for the damping option), an ES is not permitted to change its
  860.    group Network address to SNPA address mapping based on the
  861.    announcement of other ESs.
  862.  
  863.    Optionally, the ES may perform damping (resetting a Multicast
  864.    Announcement Timer corresponding to a particular group Network
  865.    address) if the conditions necessary to withhold a particular
  866.    announcement are met. In order to perform damping the following
  867.    conditions must be met: (1)The ES must be processing other ES's
  868.    announcements; (2)An ESGH PDU is received that identifies the exact
  869.    same group Network address and SNPA address pairing on a particular
  870.    subnetwork that this ES is announcing on; (3) The Multicast Holding
  871.    Timer parameter value in the ESGH PDU received is equal to or greater
  872.    than the Multicast Holding Timer value, for this subnetwork, that is
  873.    being used by the ES processing this ESGH PDU.
  874.  
  875.    ESs will utilize a local default value for their Multicast
  876.    Announcement Timer to control the period for sending out their ESGH
  877.    PDUs. The Active Multicast IS, if one exists on a particular
  878.    subnetwork, may suggest a value for ESs on the subnetwork to use for
  879.    their Multicast Announcement Timer for a specific group Network
  880.    address. In order to support the optional damping function, ESs are
  881.    required to incorporate a 25% jittering to the timer values that they
  882.    are using.
  883.  
  884. 6.1.2   Operation of ESs originating multicast PDUs
  885.  
  886.    The ES originating multicast packets identified by a specific group
  887.    Network address is not required to be a receiver of such packets (and
  888.    thus is not announcing that particular group Network address).  The
  889.    origination of multicast PDUs involves two differences to the
  890.    origination of unicast PDUs.  The two differences are: (1)The
  891.    mechanism for selecting a destination SNPA address and (2)For End
  892.    Systems attached to more than one subnet, the decision on which
  893.    subnet(s) to originate the PDUs.
  894.  
  895.  
  896.  
  897.  
  898. Marlow                                                         [Page 16]
  899.  
  900. RFC 1768                   CLNP Multicasting                  March 1995
  901.  
  902.  
  903.    The destination SNPA address used for originating each multicast
  904.    packet depends on whether there is a multicast capable IS attached to
  905.    the subnetworks. When a multicast capable IS is attached, the
  906.    decision depends on whether there is multicast address mapping
  907.    information available for that subnetwork corresponding to the group
  908.    Network address used as the destination address parameter of the
  909.    multicast packet. When there is a multicast capable IS attached to a
  910.    subnetwork and there is multicast address mapping information
  911.    available corresponding to the group Network address, then the SNPA
  912.    address obtained from the multicast address mapping information is
  913.    used.  Originating multicast packets using the destination SNPA
  914.    address used for receiving such multicast packets ensures that the
  915.    multicast packets will not require additional forwarding on the
  916.    originating subnetwork(s). When there is a multicast capable IS
  917.    attached to a subnetwork but for which there is no multicast address
  918.    mapping information available corresponding to the the group Network
  919.    address, then the SNPA address used is the "All Multicast Capable
  920.    Intermediate Systems" address.
  921.  
  922.    When there is no multicast capable IS attached to a subnetwork then
  923.    the ES originating a multicast PDU uses pre-configured information if
  924.    it is available or the "All Multicast Capable End Systems" SNPA
  925.    address when no pre-configured information is available.
  926.  
  927.    ES's attached to more than one subnetwork forward each multicast
  928.    packet that they originate onto every attached subnetwork for which
  929.    the NSAP address being used as the source address of the multicast
  930.    packet is actively being reported through the unicast ES-IS Report
  931.    Configuration function.
  932.  
  933. 6.1.3   Operation of the Active Multicast IS
  934.  
  935.    The Active Multicast IS listens in on all ESGH PDUs originated on the
  936.    subnetwork for which it is serving as the Active Multicast IS. All
  937.    subnetworks are handled independently (even if multiple subnetworks
  938.    have the same ESs attached and the IS is serving as the Active
  939.    Multicast IS for these subnetworks).
  940.  
  941.    The Active Multicast IS originates MAM PDUs, for all group Network
  942.    addresses for which it has received ESGH PDUs, on the subnetwork due
  943.    to the following operational conditions:
  944.  
  945.    1)   The IS initializes either as the Active Multicast IS after an
  946.         election with other multicast capable ISs or initializes
  947.         believing it is the only multicast capable IS;
  948.  
  949.    Note: The determination of such conditions is outside of the scope of
  950.    this specification;
  951.  
  952.  
  953.  
  954. Marlow                                                         [Page 17]
  955.  
  956. RFC 1768                   CLNP Multicasting                  March 1995
  957.  
  958.  
  959.    2)   The IS receives an ESGH PDU with a group Network address paired
  960.         to an incorrect SNPA address;
  961.  
  962.    3)   The expiration of the IS's Multicast Address Mapping Timer for
  963.         that group Network address; or
  964.  
  965.    Note: This is to prevent the expiration of Mapping Holding Timers in
  966.    ESs.
  967.  
  968.    4)   The IS receives a multicast PDU originated on the subnetwork
  969.         which used an incorrect destination SNPA address.
  970.  
  971.    Note: Of particular concern are those multicast packets using the
  972.    "All Multicast Capable Intermediate Systems" SNPA address when
  973.    another SNPA address should have been used.  In addition the
  974.    multicast capable ISs are responsible for listening in on all
  975.    multicast packets using destination SNPA addresses that are contained
  976.    within the current multicast address mapping information.
  977.  
  978.    As a result of the event driven conditions (i.e., conditions 2 or 4
  979.    above), the Active Multicast IS sends a MAM PDU with direct
  980.    information (i.e., not needing analysis of the Mask parameters).  The
  981.    Active Multicast IS limits the number of MAM PDUs that are sent out
  982.    per unit of time.  Particular MAM PDUs with direct information will
  983.    not be sent more than once per second.  MAM PDU will be sent in
  984.    response to continuing event driven conditions such that events
  985.    occurring greater than 10 seconds after the issuance of such a MAM
  986.    PDU will result in the issuance of another MAM PDU.
  987.  
  988.    The Active Multicast IS is responsible for forwarding a multicast
  989.    packet back on the subnetwork it was originated when a multicast
  990.    packet used the "All Multicast Capable Intermediate System" SNPA
  991.    address when another SNPA address should have been used.  A packet
  992.    forwarded back onto the subnetwork the multicast packet was
  993.    originated on will be given a CLNP Lifetime of "1" to prevent the
  994.    continued relaying of duplicate packets by the multicast ISs.
  995.  
  996.    The further relaying of any multicast packet originated on a
  997.    subnetwork is the responsibility of the multicast routing protocol
  998.    used and is outside the scope of this specification.
  999.  
  1000. 6.2     Definitions
  1001.  
  1002.    Active Multicast IS: The one multicast capable IS selected (via means
  1003.    outside of this specification) to originate Multicast Address Mapping
  1004.    information on a particular subnetwork.
  1005.  
  1006.  
  1007.  
  1008.  
  1009.  
  1010. Marlow                                                         [Page 18]
  1011.  
  1012. RFC 1768                   CLNP Multicasting                  March 1995
  1013.  
  1014.  
  1015.    Paired SNPA Address: The SNPA address associated with a particular
  1016.    group Network address on a specific subnetwork.
  1017.  
  1018. 6.3     Routing information supporting multicast transmission
  1019.  
  1020. 6.3.1   Multicast Announcement Information
  1021.  
  1022.    An IS should forward a multicast PDU containing a particular
  1023.    destination group Network address onto a subnetwork to which it is
  1024.    attached if and only if one or more of the ESs attached to that
  1025.    subnetwork have declared an interest in receiving multicast PDUs
  1026.    destined for that group Network address. Multicast announcement
  1027.    information enables an IS that supports CLNP multicast to dynamically
  1028.    discover, for each subnetwork to which it is attached, the group
  1029.    Network addresses for which ESs attached to that subnetwork have
  1030.    declared an interest.
  1031.  
  1032.    On a point-to-point subnetwork the multicast announcement information
  1033.    informs the Network entity, in the case where it is attached to an
  1034.    End System, of the group Network addresses for which that End System
  1035.    expects to receive multicast PDUs.
  1036.  
  1037.    On a broadcast subnetwork the multicast announcement information
  1038.    informs the multicast capable Intermediate Systems, of the group
  1039.    Network addresses for which ESs attached to that subnetwork expect to
  1040.    receive multicast PDUs.
  1041.  
  1042.    Note: Intermediate Systems with the optional OSI multicast
  1043.    capabilities do receive information identifying the SNPA address of
  1044.    ESs on the broadcast network that want PDUs with particular group
  1045.    Network addresses as their destination address; however, the critical
  1046.    information is which multicast PDUs are needed, not which ESs need
  1047.    them.
  1048.  
  1049. 6.3.2   Multicast Address Mapping Information
  1050.  
  1051.    In order to receive multicast packets destined for a particular group
  1052.    Network address, an ES may need to associate with the group Network
  1053.    address a specific SNPA address.  Multicast address mapping
  1054.    information enables an IS to inform ESs that they can receive
  1055.    multicast packets destined for a particular group Network address on
  1056.    a corresponding specific SNPA address.  In addition, multicast
  1057.    address mapping information may provide the specific destination SNPA
  1058.    addresses needed by an ES for originating multicast packets.
  1059.  
  1060.    Multicast address mapping information is not employed on point-to-
  1061.    point subnetworks.
  1062.  
  1063.  
  1064.  
  1065.  
  1066. Marlow                                                         [Page 19]
  1067.  
  1068. RFC 1768                   CLNP Multicasting                  March 1995
  1069.  
  1070.  
  1071.    Multicast address mapping information is employed on broadcast sub-
  1072.    networks to enable multicast capable Intermediate Systems to inform
  1073.    the multicast capable End Systems that they can receive, on a
  1074.    specific broadcast subnetwork, multicast packets destined for a
  1075.    particular group Network address on a corresponding specific SNPA
  1076.    address.  In addition multicast address mapping information provides
  1077.    the specific destination SNPA address, that corresponds to a
  1078.    particular group Network address, for each multicast packet that it
  1079.    originates on a specific broadcast subnetwork.
  1080.  
  1081. 6.4     Addresses
  1082.  
  1083.    All exchanges using this protocol are accomplished over a single
  1084.    subnetwork. While the control PDU's contain Network addresses (i.e.,
  1085.    group Network addresses) actual control PDU transfer is accomplished
  1086.    via Subnetwork based group addresses (i.e., group SNPA addresses).
  1087.    The following group SNPA addresses are used: (1)All Multicast Capable
  1088.    End Systems; (2)All Multicast Announcements; (3)All Multicast Capable
  1089.    Intermediate Systems and (4)a group SNPA address corresponding to a
  1090.    group Network address
  1091.  
  1092. 6.5     Timers
  1093.  
  1094.    Two additional timers are employed: (1)the Multicast Announcement
  1095.    Timer (MAT) and (2)Multicast Address Mapping Timer (MAMT). Old
  1096.    multicast announcement or multicast address mapping information shall
  1097.    be discarded after the Holding Timer expires to ensure the correct
  1098.    operation of the protocol.
  1099.  
  1100. 6.5.1   Multicast Announcement Timer
  1101.  
  1102.    The Multicast Announcement Timer is a local timer (i.e., maintained
  1103.    independently by each End System, one timer per group Network
  1104.    address) which assists in performing the Report Multicast
  1105.    Announcement function. The timer determines how often an End System
  1106.    reports its desire to receive multicast PDUs with that group Network
  1107.    address as its destination address parameter. Considerations in
  1108.    setting this timer are similar to those described for the
  1109.    Configuration timer in the ES-IS specification.
  1110.  
  1111. 6.5.2   Multicast Address Mapping Timer
  1112.  
  1113.    The Multicast Address Mapping Timer is a local timer (i.e.,
  1114.    maintained independently by an Intermediate System which is actively
  1115.    participating with End Systems to transfer multicast PDUs) which
  1116.    assists in performing the Report Multicast Address Mapping function.
  1117.    The timer determines how often an Intermediate System, actively
  1118.    participating with End Systems for the transfer of multicast PDUs,
  1119.  
  1120.  
  1121.  
  1122. Marlow                                                         [Page 20]
  1123.  
  1124. RFC 1768                   CLNP Multicasting                  March 1995
  1125.  
  1126.  
  1127.    reports the Multicast Address Mapping for a particular group Network
  1128.    address. The shorter the Multicast Address Mapping Timer, the more
  1129.    quickly End Systems on the subnetwork will become aware of the
  1130.    correct address mapping which may change due to the Intermediate
  1131.    System becoming available or unavailable. There is a trade off
  1132.    between increased responsiveness and increased use of resources in
  1133.    the subnetwork and in the End Systems.
  1134.  
  1135. 6.6     Extensions to the current protocol functions
  1136.  
  1137.    In order to support multicast transmissions the following optional
  1138.    ES-IS protocol functions will be implemented:
  1139.  
  1140. 6.6.1   Report Configuration by Intermediate Systems
  1141.  
  1142.    All multicast capable Intermediate Systems on a subnetwork shall use
  1143.    the Multicast Capable option in all ISH PDUs that they originate.
  1144.    This will provide multicast capable End Systems with a way to
  1145.    determine that a multicast capable Intermediate System is operating
  1146.    on a particular subnetwork.
  1147.  
  1148. 6.6.2   Query Configuration
  1149.  
  1150.    Note: The Query Configuration function cannot be performed to find
  1151.    the corresponding SNPA address of a group Network address since the
  1152.    addressing information needed is the corresponding group SNPA address
  1153.    and not the SNPA address of a particular End System responding. On a
  1154.    large broadcast subnetwork, many different Configuration Responses
  1155.    could result each incorporating a different End System Address. While
  1156.    it is possible to design a Query Configuration for use with
  1157.    multicast, this function does not appear to be required given the use
  1158.    of the "All Multicast Capable End Systems" address for supplying a
  1159.    SNPA address when the group SNPA address is not known.
  1160.  
  1161. 6.7     Multicast Announcement
  1162.  
  1163. 6.7.1   Report Multicast Announcement Function by End Systems
  1164.  
  1165.    An End System which needs to receive or continue to receive any
  1166.    multicast PDUs (i.e., PDUs with group Network addresses as their
  1167.    destination address), constructs and transmits ESGH PDUs to inform
  1168.    multicast capable Intermediate Systems of the set of group Network
  1169.    address destinations for which it wishes to receive PDUs. This may be
  1170.    done by constructing ESGH PDUs for each group Network address.
  1171.    Alternatively, ESGH PDUs may be constructed which convey information
  1172.    about more than one group Network address at a time, up to the limits
  1173.    imposed by the permitted SNSDU size and the maximum header size of
  1174.    the ESGH PDU. Each ESGH PDU is transmitted by issuing an SN-
  1175.  
  1176.  
  1177.  
  1178. Marlow                                                         [Page 21]
  1179.  
  1180. RFC 1768                   CLNP Multicasting                  March 1995
  1181.  
  1182.  
  1183.    UNITDATA.Request with the following parameters:
  1184.  
  1185.    SN_Userdata (SNSDU) <- ESGH PDU
  1186.  
  1187.    SN_Destination _Address <- multi-destination address that indicates
  1188.    "All Multicast Announcements"
  1189.  
  1190.    If an End System is attached to more than one subnetwork, the
  1191.    information about each group Network address desired for receiving on
  1192.    a particular subnetwork serving the End System shall be transmitted
  1193.    via that subnetwork. It is permissible for an End System to report
  1194.    group Network addresses on multiple subnetworks; however, duplicate
  1195.    multicast PDUs should be anticipated.
  1196.  
  1197.    The Group Address Pair parameter carries a list of Group Network
  1198.    Addresses, each paired with its associated SNPA address. This
  1199.    information is used by the Active Multicast IS to determine whether a
  1200.    Multicast Address Mapping PDU should be emitted to update the
  1201.    association between Group Network Addresses and SNPA addresses.
  1202.  
  1203.    The Holding Time (HT) field is set to approximately twice the ES's
  1204.    Multicast Announcement Timer (MAT) parameter. The value shall be
  1205.    large enough so that even if every other ESGH PDU is discarded (due
  1206.    to lack of resources), or otherwise lost in the subnetwork, the
  1207.    multicast announcement information will still be maintained. The
  1208.    value should be set small enough so that Intermediate Systems
  1209.    resources are not needlessly consumed when the ES no longer wishes to
  1210.    receive PDUs destined to a group Network address.
  1211.  
  1212.    Note: When combining multiple group Network addresses in a single
  1213.    ESGH PDU, it should be realized that there is a single Holding Time
  1214.    parameter associated with all of these addresses.
  1215.  
  1216. 6.7.1.1  Generating Jitter on Multicast Announcement Timers
  1217.  
  1218.    The ES shall apply a 25% jitter to its Multicast Announcement Timer
  1219.    (MAT) parameter. When ESGH PDUs are transmitted as a result of timer
  1220.    expiration, there is a danger that the timers of individual systems
  1221.    may become synchronised. The result of this is that the traffic
  1222.    distribution will contain peaks. Where there are a large number of
  1223.    synchronised systems, this can cause overloading of both the
  1224.    transmission medium and the systems receiving the PDUs. In order to
  1225.    prevent this from occurring, all periodic timers, the expiration of
  1226.    which can cause the transmission of PDUs, shall have "jitter"
  1227.    introduced as defined in the following algorithm.
  1228.  
  1229.  
  1230.  
  1231.  
  1232.  
  1233.  
  1234. Marlow                                                         [Page 22]
  1235.  
  1236. RFC 1768                   CLNP Multicasting                  March 1995
  1237.  
  1238.  
  1239.            CONSTANT
  1240.            Jitter = 25;
  1241.            Resolution = 100;
  1242.  
  1243.            (* The timer resolution in ms *)
  1244.            PROCEDURE Random(max: Integer): Integer;
  1245.  
  1246.            (* This procedure delivers a Uniformly distributed random
  1247.            integer R such that 0 < R <max *)
  1248.                    PROCEDURE WaitUntil(time: Integer)
  1249.  
  1250.                    (* This procedure waits the specified number of
  1251.                    ms and then returns *)
  1252.                    PROCEDURE CurrentTime(): Integer
  1253.  
  1254.                    (* This procedure returns the current time in ms *)
  1255.  
  1256.            PROCEDURE
  1257.            DefineJitteredTimer(baseTimeValueInSeconds : Integer;
  1258.            expirationAction : Procedure);
  1259.  
  1260.            VAR
  1261.            baseTimeValue, maximumTimeModifier, waitTime : Integer;
  1262.            nextexpiration : Time;
  1263.  
  1264.            BEGIN
  1265.            baseTimeValue := baseTimeValueInSeconds * 1000 / Resolution;
  1266.            maximumTimeModifier := baseTimeValue * Jitter / 100;
  1267.            (* Compute maximum possible jitter *)
  1268.  
  1269.            WHILE running DO
  1270.  
  1271.                    BEGIN
  1272.  
  1273.                     (*First compute next expiration time *)
  1274.                    randomTimeModifier := Random(maximumTimeModifier);
  1275.                    waitTime:= baseTimeValue - randomTimeModifier;
  1276.                    nextexpiration := CurrentTime() + waitTime;
  1277.  
  1278.                     (* Then perform expiration Action *)
  1279.                    expirationAction;
  1280.                    WaitUntil(nextexpiration);
  1281.  
  1282.            END (* of Loop *)
  1283.  
  1284.            END (* of DefineJitteredTimer *)
  1285.  
  1286.  
  1287.  
  1288.  
  1289.  
  1290. Marlow                                                         [Page 23]
  1291.  
  1292. RFC 1768                   CLNP Multicasting                  March 1995
  1293.  
  1294.  
  1295.    Thus the call "DefineJitteredTimer(HelloTime, SendHelloPDU);" where
  1296.    "HelloTime" is 10 seconds, will cause the action "SendHelloPDU" to be
  1297.    performed at random intervals of between 7.5 and 10 seconds. The
  1298.    essential point of this algorithm is that the value of
  1299.    "randomTimeModifier" is randomised within the inner loop. Note that
  1300.    the new expiration time is set immediately on expiration of the last
  1301.    interval, rather than when the expiration action has been completed.
  1302.  
  1303.    The time resolution shall be less than or equal to 100 ms. It is
  1304.    recommended to be less than or equal to 10ms. The time resolution is
  1305.    the maximum interval than can elapse without there being any change
  1306.    in the value of the timer. The periodic transmission period shall be
  1307.    random or pseudo-random in the specified range. with uniform
  1308.    distribution across similar implementations.
  1309.  
  1310.    Note: Applying jitter to the MAT parameter is required in order to
  1311.    support the optional Damping function. If no jitter is applied on a
  1312.    subnetwork where many ESs are requesting a particular multicast PDU
  1313.    it is likely that they will have the same value for their MAT and
  1314.    these timers may all become synchronised. Such synchronisation will
  1315.    result in peaks in the distribution of traffic as described above.
  1316.    The resulting overloading of the transmission medium and the systems
  1317.    receiving the PDUs will negate any beneficial use of the Damping
  1318.    function (since systems may be attempting to transmit their own ESGH
  1319.    PDUs at the time they receive ESGH PDUs originated by other ESs with
  1320.    the same group Network address.
  1321.  
  1322. 6.7.2   Record Multicast Announcement Function
  1323.  
  1324.    The Record Multicast Announcement function receives ESGH PDUs,
  1325.    extracts the multicast announcement information and updates the
  1326.    information in its routing information base.
  1327.  
  1328.    The receiving system is not required to process any option fields in
  1329.    a received ESGH PDU.
  1330.  
  1331.    Note: When a system chooses to process these optional fields, the
  1332.    precise actions are not specified by this International Standard.
  1333.  
  1334. 6.7.2.1  Record Multicast Announcement Function by Intermediate Systems
  1335.  
  1336.    On receipt of an ESGH PDU an IS with the optional multicast
  1337.    capabilities extracts the configuration information and stores the
  1338.    {group Network address, subnetwork} in its routing information base
  1339.    replacing any other information for the same entry.
  1340.  
  1341.  
  1342.  
  1343.  
  1344.  
  1345.  
  1346. Marlow                                                         [Page 24]
  1347.  
  1348. RFC 1768                   CLNP Multicasting                  March 1995
  1349.  
  1350.  
  1351.    The Active Multicast IS upon receipt of an ESGH PDU also extracts the
  1352.    Paired SNPA Address parameter corresponding to each group Network
  1353.    address in the ESGH PDU. If the Active Multicast IS has a mapping for
  1354.    a group Network address carried in the ESGH for which the paired SNPA
  1355.    address does not match, the Report Multicast Address Mapping function
  1356.    is performed.
  1357.  
  1358. 6.7.2.2  Optional Damping Function
  1359.  
  1360.    An ES with the optional capabilities to support multicast transfer
  1361.    may decide to process ESGH PDUs multicast by other End Systems. There
  1362.    is potentially some reduction in network traffic by doing this. An ES
  1363.    requesting to receive multicast PDUs is permitted to reset its
  1364.    Multicast Announcement Timer corresponding to one group Network
  1365.    address on one subnetwork upon receiving an ESGH PDU from another ES
  1366.    under the following circumstances:
  1367.  
  1368.    a)   The {group Network address, paired SNPA address} received on a
  1369.         particular subnetwork matches that of the ES processing the ESGH
  1370.         PDU for that subnetwork.
  1371.  
  1372.    b)   The Holding Timer parameter value in the ESGH PDU received is
  1373.         equal to or greater than the Holding Timer value for the, group
  1374.         Network address, being used by the ES processing this PDU.
  1375.  
  1376. 6.7.3 Flush Old Multicast Announcement Function
  1377.  
  1378.    The Flush Old Multicast Announcement function is executed to remove
  1379.    multicast announcement entries in its routing information base whose
  1380.    Holding Timer has expired. When the Holding Timer for a group Network
  1381.    address expires, this function removes the corresponding entry from
  1382.    the routing information base of the local IS for the corresponding
  1383.    subnetwork.
  1384.  
  1385. 6.8     Multicast Address Mapping
  1386.  
  1387. 6.8.1 Report Multicast Address Mapping Function by Intermediate Systems
  1388.  
  1389.    The Active Multicast Intermediate System constructs a MAM PDU,
  1390.    corresponding to a group Network address for which it received via
  1391.    the Record Multicast Announcement function, and issues these PDUs
  1392.    under the following circumstances:
  1393.  
  1394.    a)   The IS initializes either as the Active Multicast IS after an
  1395.         election with other multicast capable ISs or initializes after
  1396.         determining it is the only multicast capable IS (the
  1397.         determination of such conditions are outside of the scope of
  1398.         this standard), or
  1399.  
  1400.  
  1401.  
  1402. Marlow                                                         [Page 25]
  1403.  
  1404. RFC 1768                   CLNP Multicasting                  March 1995
  1405.  
  1406.  
  1407.    b)   The IS receives an ESGH PDU with a group Network address paired
  1408.         to an SNPA address other than the SNPA address contained in the
  1409.         Active Multicast IS's multicast address mapping information for
  1410.         that group Network address, or
  1411.  
  1412.    Note: The Active Multicast IS determines which mappings are correct.
  1413.    Pre-configured mappings which are used prior to the initialization of
  1414.    the Active Multicast IS may be determined to be incorrect by the
  1415.    Active Multicast IS.
  1416.  
  1417.    c)   The expiration of the IS's Multicast Address Mapping Timer for
  1418.         that group Network address.
  1419.  
  1420.    Note: This is to prevent the expiration of Holding Timers in ESs.
  1421.  
  1422.    d)   The IS receives a multicast PDU originated on the subnetwork
  1423.         which used an incorrect destination SNPA address.
  1424.  
  1425.    Note: Of particular concern are those multicast packets using the
  1426.    "All Multicast Capable Intermediate Systems" SNPA address when
  1427.    another SNPA address should have been used.  The Originating
  1428.    Subnetwork Forwarding function is performed if this event occurs (see
  1429.    section 6.11).
  1430.  
  1431.    Note: The multicast capable ISs need to receive multicast packets on
  1432.    all SNPA addresses that are contained in the current multicast
  1433.    address mapping information for the subnetwork.  The multicast
  1434.    capable ISs are not required to receive multicast packets on any SNPA
  1435.    addresses other than those contained in the current multicast address
  1436.    mapping information and the "All Multicast Capable Intermediate
  1437.    Systems" SNPA address.
  1438.  
  1439.    Circumstances b) and d) are the event driven conditions for the
  1440.    Active Multicast IS to construct and issue a MAM PDU.  The Active
  1441.    Multicast IS shall limit the number of MAM PDUs issued per unit of
  1442.    time.  MAM PDUs with identical information shall not be issued more
  1443.    than once per second.  Event conditions occurring 10 seconds after
  1444.    the last issue of an appropriate MAM PDU shall result in the issuance
  1445.    of another such MAM PDU.
  1446.  
  1447.    The IS serving as the Active Multicast Intermediate System may
  1448.    construct a MAM PDU for each group Network address. Alternatively,
  1449.    MAM PDUs may be constructed which convey information about more than
  1450.    one group Network address at a time, up to the limits imposed by the
  1451.    permitted SNSDU size and the maximum header size of the MAM PDU. The
  1452.    IS performs all multicast address mapping functions independently for
  1453.    each of its subnetworks even if this IS is the Active Multicast IS on
  1454.    multiple subnetworks. Each MAM PDU is transmitted by issuing an SN-
  1455.  
  1456.  
  1457.  
  1458. Marlow                                                         [Page 26]
  1459.  
  1460. RFC 1768                   CLNP Multicasting                  March 1995
  1461.  
  1462.  
  1463.    UNITDATA.Request with the following parameters:
  1464.  
  1465.    SN_Userdata (SNSDU) <- MAM PDU
  1466.  
  1467.    SN_Destination _Address <- multi-destination address that indicates
  1468.    "All Multicast Capable End Systems"
  1469.  
  1470.    The Holding Time (HT) field is set to approximately twice the
  1471.    Intermediate System's Multicast Address Mapping Timer (MAMT)
  1472.    parameter.  This variable shall be set to a value large enough so
  1473.    that even if every other MAM PDU, for a particular group Network
  1474.    address, is discarded (due to lack of resources), or otherwise lost
  1475.    in the subnetwork, the multicast address mapping information will
  1476.    still be maintained. The value should be set small enough so that End
  1477.    Systems will quickly cease to use the multicast address mappings
  1478.    supplied by ISs that have failed.
  1479.  
  1480.    Note: -- The Holding Timer parameter value applies to all group
  1481.    Network addresses called out in the MAM PDU.
  1482.  
  1483.    The Group Address Pair parameter is used to convey the association
  1484.    between Group Network Addresses and SNPA addresses.
  1485.  
  1486.    Optionally, the Active Multicast IS may include information in the
  1487.    MAM PDU indicating a larger population of group Network addresses to
  1488.    which the same multicast address mapping information applies. There
  1489.    are two optional fields for this purpose: the Group Network Address
  1490.    Mask option and the Paired SNPA Address Mask option.
  1491.  
  1492.    There are three permitted cases for including or excluding the masks.
  1493.    In the first case, both masks are absent. In this case the MAM PDU
  1494.    conveys information about one set of enumerated group Network
  1495.    addresses only.
  1496.  
  1497.    Note: -- Multiple group address pairs may be contained in a single
  1498.    MAM PDU.
  1499.  
  1500.    In the second case, the MAM PDU contains a Group Network Address Mask
  1501.    but no Paired SNPA Address Mask. In this case, the MAM PDU conveys
  1502.    information about an equivalence class of group Network addresses.
  1503.    The information reveals that multiple group Network addresses are
  1504.    mapped to the same SNPA address.
  1505.  
  1506.    In the third case, the MAM PDU contains both masks. As in the second
  1507.    case, the MAM PDU conveys information about an equivalence class of
  1508.    group Network addresses. But in this case, the information reveals
  1509.    that the SNPA addresses for the equivalence class of group Network
  1510.    address are embedded in the group Network address. In particular the
  1511.  
  1512.  
  1513.  
  1514. Marlow                                                         [Page 27]
  1515.  
  1516. RFC 1768                   CLNP Multicasting                  March 1995
  1517.  
  1518.  
  1519.    Paired SNPA Address Mask indicates the location of the SNPA address
  1520.    in the group Network Address(es).
  1521.  
  1522.    The Active Multicast IS shall construct a MAM PDU with direct
  1523.    information, not needing analysis of the Mask parameters, in response
  1524.    to the occurrence of an event driven condition.  The Active Multicast
  1525.    IS may provide additional information in such a MAM PDU via the use
  1526.    of Mask parameters.
  1527.  
  1528.    An IS may suggest a value for End Systems on the local subnetwork to
  1529.    use as their Multicast Announcement Timers, for a specific group
  1530.    Network address, by including the Suggested ES Multicast Announcement
  1531.    Timer (ESMAT) parameter in the transmitted MAM PDU. Setting this
  1532.    parameter permits the Active Multicast IS to influence the frequency
  1533.    with which ESs transmit ESGH PDUs.
  1534.  
  1535.    Note: If the ESMAT parameter is used, the one value permitted in the
  1536.    MAM PDU is suggested for all group Network addresses called out in
  1537.    the MAM PDU.
  1538.  
  1539. 6.8.2   Record Multicast Address Mapping Function by End Systems
  1540.  
  1541.    The Record Multicast Address Mapping function receives MAM PDUs,
  1542.    extracts the multicast address mapping information and updates the
  1543.    information in its routing information base. The receiving system is
  1544.    not required to process any option fields in a received MAM PDU with
  1545.    the exception of the Suggested ES Multicast Announcement Timer
  1546.    (ESMAT) parameter.
  1547.  
  1548.    Note: When a system chooses to process these optional fields, the
  1549.    precise actions are not specified by this International Standard.
  1550.  
  1551.    On receipt of a MAM PDU an ES with the optional multicast
  1552.    capabilities extracts the multicast address mapping information and
  1553.    stores the {group Network address, paired SNPA address} for a
  1554.    particular subnetwork in its routing information base replacing any
  1555.    other information for the same group Network address and subnetwork.
  1556.  
  1557.    In addition, an ES shall set its Multicast Announcement Timer,
  1558.    corresponding to the group Network address for which it is performing
  1559.    the Record Multicast Address Mapping function, based on receipt of a
  1560.    MAM PDU, corresponding to that group Network address, containing an
  1561.    ESMAT parameter.
  1562.  
  1563.    Note: While an ES may process ESGH PDUs multicast by other ESs to
  1564.    support the optional Damping function, an ES is not permitted to
  1565.    change its own mapping due to the mapping found in other ES's ESGH
  1566.    PDUs.
  1567.  
  1568.  
  1569.  
  1570. Marlow                                                         [Page 28]
  1571.  
  1572. RFC 1768                   CLNP Multicasting                  March 1995
  1573.  
  1574.  
  1575. 6.8.3   Flush Old Multicast Address Mapping Function by End Systems
  1576.  
  1577.    The Flush Old Multicast Address Mapping function is executed to
  1578.    remove multicast address mapping entries in its routing information
  1579.    base whose corresponding Holding Timer has expired. When such a
  1580.    Holding Timer for a multicast address mapping expires, this function
  1581.    removes the corresponding entry from its routing information base for
  1582.    the corresponding SNPA.
  1583.  
  1584. 6.9     Paired SNPA Address Selection Function by End Systems
  1585.  
  1586.    An End System shall pair each group Network address with an
  1587.    associated SNPA address to support receiving (e.g., performing the
  1588.    Report Multicast Announcement function) and originating multicast
  1589.    PDUs.
  1590.  
  1591. 6.9.1  Paired SNPA Address Selection for Receiving Multicast PDUs
  1592.  
  1593.    An End System always has a paired SNPA address for every active group
  1594.    Network address on a particular subnetwork. This mapping is obtained
  1595.    by:
  1596.  
  1597.    a)   recording a multicast address mapping which is maintaining an
  1598.         active holding timer, or if there has been no dynamic
  1599.         information received, by
  1600.  
  1601.    b)   having pre-configured multicast address mapping information, or
  1602.         if neither dynamic nor pre-configured information is available,
  1603.         by
  1604.  
  1605.    c)   mapping the "All Multicast Capable End Systems" multi-
  1606.         destination address to the group Network address.
  1607.  
  1608. 6.9.2  Paired SNPA Address Selection for Originating Multicast PDUs
  1609.  
  1610.    An End System, originating a multicast PDU, pairs a SNPA address to
  1611.    the group Network address.  This mapping is obtained in the following
  1612.    manner:
  1613.  
  1614.    a)   If there is a multicast capable IS reachable on the subnetwork
  1615.         then the SNPA address used by an End System originating a multi-
  1616.         cast PDU is either the paired SNPA address obtained from the
  1617.         multicast address mapping information associated with the group
  1618.         Network address in the multicast PDU's Destination address
  1619.         parameter or if there is no valid entry for the group Network
  1620.         address by using the "All Multicast Capable Intermediate Sys-
  1621.         tems" multi-destination address, or if there is no multicast
  1622.         capable Intermediate System on the subnetwork, by
  1623.  
  1624.  
  1625.  
  1626. Marlow                                                         [Page 29]
  1627.  
  1628. RFC 1768                   CLNP Multicasting                  March 1995
  1629.  
  1630.  
  1631.    Note: Multicast address mapping information is valid if the Holding
  1632.    Timer associated with it has not expired.
  1633.  
  1634.    Note: An ES can determine if a multicast capable IS is reachable on
  1635.    the subnetwork by having for that subnetwork either (1)multicast
  1636.    address mapping information or (2)routing information received via an
  1637.    ISH PDU containing a Multicast Capable optional parameter.  In either
  1638.    case the information must be valid (i.e., the Holding Timer for the
  1639.    information must not have expired).
  1640.  
  1641.    b)   having pre-configured multicast address mapping information, or
  1642.         if neither a multicast capable Intermediate System is present on
  1643.         the subnetwork nor pre-configured information is available, by
  1644.  
  1645.    c)   mapping the "All Multicast Capable End Systems" multi-
  1646.         destination address to the group Network address.
  1647.  
  1648. 6.10    Extensions to the ISO CLNP Route Function by End Systems
  1649.  
  1650.    An End System attached to more than one subnetwork shall determine
  1651.    when originating a multicast PDU whether to forward this multicast
  1652.    PDU to more than one subnetwork or not.  End Systems shall originate
  1653.    each multicast PDU on all subnetworks for which the ISO ES-IS
  1654.    Configuration function is actively reporting the NSAP address
  1655.    contained in the Source Address parameter of the multicast PDU.  As a
  1656.    result of this function multiple invocations of the ISO CLNP
  1657.    Forwarding function may result when such an ES originates a multicast
  1658.    PDU.
  1659.  
  1660. 6.11    Originating Subnetwork Forwarding Function by Intermediate
  1661.         Systems
  1662.  
  1663.    The Active Multicast IS upon receiving a multicast PDU originated on
  1664.    a subnetwork which used the "All Multicast Capable Intermediate
  1665.    Systems" SNPA address when another SNPA address should have been
  1666.    used, performs the Originating Subnetwork Forwarding function.  The
  1667.    multicast address mapping information defines the correct SNPA
  1668.    address pairings for a given subnetwork.  The Originating Subnetwork
  1669.    Forwarding function forwards the multicast PDU back on subnetwork it
  1670.    was originated on.  In the case that the ES was attached to more than
  1671.    one subnetwork and originated the multicast PDU on more than one
  1672.    subnetwork, the Active Multicast IS for each subnetwork performs the
  1673.    Originating Subnetwork Forwarding function for the subnetwork that
  1674.    they are responsible for.
  1675.  
  1676.    The Active Multicast IS obtains the contents for the multicast PDU
  1677.    for the Originating Subnetwork Forwarding function by using the
  1678.    contents of the multicast PDU received with the incorrect destination
  1679.  
  1680.  
  1681.  
  1682. Marlow                                                         [Page 30]
  1683.  
  1684. RFC 1768                   CLNP Multicasting                  March 1995
  1685.  
  1686.  
  1687.    SNPA address and replacing the original PDU Lifetime field with the
  1688.    value one (0000 0001).  The Active Multicast IS performs the ISO 8473
  1689.    PDU Composition function and forwards the PDU to the subnetwork that
  1690.    the PDU was originated on using the ISO 8473 Forwarding function with
  1691.    the correct destination SNPA address.
  1692.  
  1693.    Note: The PDU Lifetime field is set to "one" to ensure that ISs
  1694.    attached to the originating subnetwork do not forward this PDU on.
  1695.    Such ISs should have received the PDU when it was originated since
  1696.    this function is only performed in the event of receiving a multicast
  1697.    PDU incorrectly addressed to the "All Multicast Capable Intermediate
  1698.    Systems" SNPA address.
  1699.  
  1700. 6.12    Structure and Encoding of PDUs
  1701.  
  1702.    The ES-IS multicast control functions are supported via the exchange
  1703.    of ESGH and MAM PDUs.  The one exception to this is that a new
  1704.    optional parameter, the Multicast Capable parameter, is provided for
  1705.    use within the ISH PDU.
  1706.  
  1707. 6.12.1  PDU Type Codes
  1708.  
  1709.    The Multicast Announcement is accomplished via the transfer of End
  1710.    System Group Hello (ESGH) PDUs. The PDU type code for an ESGH PDU is
  1711.    "0 0 1 0 1". The Multicast Address Mapping (MAM) is accomplished via
  1712.    the transfer of Multicast Address Mapping PDUs. The PDU type code for
  1713.    a MAM PDU is "0 0 1 1 1".
  1714.  
  1715. 6.12.2  Hold Time field
  1716.  
  1717.    The Holding Time field specifies the maximum time for the receiving
  1718.    Network entity to retain the multicast announcement or multicast
  1719.    address mapping information contained in the PDU.
  1720.  
  1721. 6.12.3  Structure of Addressing Parameters
  1722.  
  1723.    The ESGH and MAM PDUs carry one or more group Network addresses
  1724.    (GNAs) each with their associated Paired SNPA Address (PSA).
  1725.  
  1726. 6.12.4  Group Address Pair Parameter for ESGH and MAM PDUs
  1727.  
  1728.    The Group Address Pair parameter is a list of one or more group
  1729.    Network addresses each with their associated Paired SNPA address. The
  1730.    group Network address identifies specific multicast PDUs and the
  1731.    Paired SNPA address is the SNPA address on which the ES expects to
  1732.    receive such multicast PDUs on that subnetwork. It is encoded in the
  1733.    ESGH and MAM PDUs as shown in Figure 1.
  1734.  
  1735.  
  1736.  
  1737.  
  1738. Marlow                                                         [Page 31]
  1739.  
  1740. RFC 1768                   CLNP Multicasting                  March 1995
  1741.  
  1742.  
  1743.                                                               Octet
  1744.         ,----------------------------------------------------,
  1745.         |        Number of Group Address Pairs               |  10
  1746.         |----------------------------------------------------|
  1747.         |   Group Network Address Length Indicator (GNAL)    |  11
  1748.         |----------------------------------------------------|
  1749.         |                                                    |  12
  1750.         :           Group Network Address (GNA)              :
  1751.         |                                                    |
  1752.         |----------------------------------------------------|
  1753.         |   Paired SNPA Address Length Indicator (PSAL)      |
  1754.         |----------------------------------------------------|
  1755.         |                                                    |
  1756.         :            Paired SNPA Address (PSA)               :
  1757.         |                                                    |
  1758.         |----------------------------------------------------|
  1759.         |                       GNAL                         |
  1760.         |----------------------------------------------------|
  1761.         |                                                    |
  1762.         :                       GNA                          :
  1763.         |                                                    |
  1764.         |----------------------------------------------------|
  1765.         |                       PSAL                         |
  1766.         |----------------------------------------------------|
  1767.         |                                                    |
  1768.         :                       PSA                          :
  1769.         |                                                    | m-1
  1770.         '----------------------------------------------------'
  1771.  
  1772.         Figure 1 - ESGH and MAM PDUs - - Group Address Pair Parameter
  1773.  
  1774. 6.12.5  Extensions to the current Option Parameters
  1775.  
  1776.    The Security and Priority optional parameters may be carried in a
  1777.    ESGH PDU. There is no Security or Priority option for the MAM PDU.
  1778.  
  1779. 6.12.6  Suggested ES Multicast Announcement Timer
  1780.  
  1781.    The ESMAT parameter may appear only in the MAM PDU
  1782.  
  1783.    The ESMAT parameter conveys the value that an IS requests the
  1784.    receiving ESs to use as their local Multicast Announcement Timer.
  1785.  
  1786.    Parameter Code:         1100 0111
  1787.  
  1788.    Parameter Length:       two octets
  1789.  
  1790.    Parameter Value:        ESMAT in units of seconds.
  1791.  
  1792.  
  1793.  
  1794. Marlow                                                         [Page 32]
  1795.  
  1796. RFC 1768                   CLNP Multicasting                  March 1995
  1797.  
  1798.  
  1799. 6.12.7  Multicast Capable
  1800.  
  1801.    The Multicast Capable option may appear only in the ISH PDU
  1802.  
  1803.    The Multicast Capable options consists only of a one octet code and a
  1804.    one octet parameter length field, there is no parameter field.
  1805.  
  1806.    Parameter Code:         1100 1000
  1807.  
  1808.    Parameter Length:       zero octets
  1809.  
  1810.    Parameter Value:        none (parameter does not exist).
  1811.  
  1812. 6.12.8  Group Network Address Mask
  1813.  
  1814.    The Group Network Address Mask option may only appear in the MAM PDU.
  1815.  
  1816.    The Group Network Address Mask parameter indicates that the multicast
  1817.    address mapping information applies to a larger population of group
  1818.    Network Addresses than the group Network address(es) contained in the
  1819.    MAM PDU indicates. When this option is provided in a MAM PDU, the
  1820.    masking relationship contained must be valid for all group Network
  1821.    addresses contained in this PDU. An End System may ignore this
  1822.    parameter.
  1823.  
  1824.    The Group Network Address Mask establishes an equivalence class of
  1825.    group Network addresses to which the same multicast address mapping
  1826.    information applies. To determine whether or not a trial group
  1827.    Network address falls within the equivalence class, the ES aligns the
  1828.    trial group Network address with the Group Network Address Mask
  1829.    padding the latter with trailing zero octets if necessary. If in all
  1830.    bit positions where the Group Network Address Mask is "1" the trial
  1831.    group Network address matches the Group Network Address field of the
  1832.    Group Address Pair parameter of the MAM PDU, then the trial group
  1833.    Network address belongs to the equivalence class described by the MAM
  1834.    PDU.
  1835.  
  1836.    The Group Network Address Mask parameter has additional semantics
  1837.    when considered with the Paired SNPA Address Mask parameter.
  1838.  
  1839.    Parameter Code:         1110 0011
  1840.  
  1841.    Parameter Length:       variable, up to 20 octets
  1842.  
  1843.    Parameter Value:        a comparison mask of octets to be
  1844.                            aligned with the Group Network Address
  1845.                            field of the Group Address Pair
  1846.                            parameter of the MAM PDU.
  1847.  
  1848.  
  1849.  
  1850. Marlow                                                         [Page 33]
  1851.  
  1852. RFC 1768                   CLNP Multicasting                  March 1995
  1853.  
  1854.  
  1855. 6.12.9 Paired SNPA Address Mask
  1856.  
  1857.    The Paired SNPA Address Mask option may only appear in the MAM PDU.
  1858.  
  1859.    When the Paired SNPA Address Mask is present, the equivalence class
  1860.    defined by the Group Network Address Mask also has common structure
  1861.    below the Group Network Address Mask; i.e., in the portion of the
  1862.    group Network address where the Group Network Address Mask is
  1863.    logically "0".  The Paired SNPA Address Mask supplies additional
  1864.    information about the structure, by indicating certain bit positions
  1865.    within the space "below" the Group Network Address Mask.
  1866.    Specifically, the Paired SNPA Address Mask indicates the location of
  1867.    the Paired SNPA address in the Group Network Address.
  1868.  
  1869.    This parameter may appear in a MAM PDU only if the Group Network
  1870.    Address Mask is also present. When this option is provided in a MAM
  1871.    PDU, the masking relationship contained must be valid for all group
  1872.    Network addresses contained in this PDU. An ES receiving such a MAM
  1873.    PDU may safely ignore both masks. However (since presence of both
  1874.    masks dictates different functional behavior than the presence of the
  1875.    Group Network Address Mask alone) an ES shall not ignore one of the
  1876.    masks while heeding the other.
  1877.  
  1878.    Parameter Code:         1110 0100
  1879.  
  1880.    Parameter Length:       variable
  1881.  
  1882.    Parameter Value:        a comparison mask of octets to be
  1883.                            aligned with the Group Network Address
  1884.                            field(s) of the Group Address Pair
  1885.                            parameter of the MAM PDU.
  1886.  
  1887. 6.12.9.1 Mask Parameters Example
  1888.  
  1889.    This section provides examples of using the Group Network Address
  1890.    Mask and the Paired SNPA Address Mask.  The examples given are for an
  1891.    Internet usage of CLNP Multicasting across subnetworks using IEEE 802
  1892.    addressing.  For these examples the group Network address format is:
  1893.  
  1894.                 +-----+----------------------------------------+
  1895.                 | IDP | Upper DSP | Embedded SNPA address | SEL|
  1896.                 +-----+-----------+-----------------------+----+
  1897.        octets:  |  3  |    10     |           6           |  1 |
  1898.                 +-----+-----------+-----------------------+----+
  1899.  
  1900.    Thus the group Network address used is 20 octets.  For these
  1901.    examples, the only field considered is the Embedded SNPA address
  1902.    field and its placement within the group Network address.
  1903.  
  1904.  
  1905.  
  1906. Marlow                                                         [Page 34]
  1907.  
  1908. RFC 1768                   CLNP Multicasting                  March 1995
  1909.  
  1910.  
  1911.    In the first example it is the policy in "this part of the Internet"
  1912.    to map the Embedded SNPA address into the IEEE 802 address space
  1913.    reserved by IEEE 802 for group addressing using LOCAL assignment,
  1914.    this corresponds to all 48 bit values with the two low order bits of
  1915.    the first octet set to "11".
  1916.  
  1917.    The Active Multicast Intermediate System on this subnetwork may
  1918.    construct a MAM PDU to map, for this example, a group Network address
  1919.    of {13 octets, 03-00-DA-DA-DA-DA, 1 octet} and a paired SNPA address
  1920.    of 03-00-DA-DA-DA-DA.  In addition the Active Multicast Intermediate
  1921.    System can include in the MAM PDU a Group Network Address Mask of
  1922.    FF-FF-FF-FF-FF-FF-FF-FF-FF-FF-FF-FF-FF-03-00-00-00-00-00-00.
  1923.  
  1924.    With this parameter, all group Network addresses which share the
  1925.    identical first 13 octet and with "11" in the two low order bits of
  1926.    the 14th octet are put in an equivalence class and share the same
  1927.    mapping information. If this were the only option present then all of
  1928.    these group Network addresses would all have a paired SNPA address of
  1929.    03-00-DA-DA-DA-DA.
  1930.  
  1931.    In order to map the group Network addresses to the range of IEEE
  1932.    addresses of this example, the MAM PDU must also contain a Paired
  1933.    SNPA Address Mask.  The Paired SNPA Address Mask identifies where the
  1934.    SNPA Address is contained within the group Network addresses (defined
  1935.    by the equivalence class formed by the Group Network Address Mask
  1936.    within the same PDU).  For this example the Paired SNPA Address Mask
  1937.    is 00-00-00-00-00-00-00-00-00-00-00-00-00-FF-FF-FF-FF-FF-FF-00.
  1938.  
  1939.    As a second example, all group Network addresses with a specific OUI
  1940.    (organizationally unique identifier) using the twenty octet group
  1941.    Network address format provided above are mapped to their embedded
  1942.    SNPA address.  An OUI is assigned by IEEE 802 and is three octets in
  1943.    length.  The OUI is contained in the first three address octets of a
  1944.    GLOBALLY assigned IEEE 802 address.  For this example the MAM PDU
  1945.    must contain the following:
  1946.  
  1947.    1.   A group Network address contained within the MAM PDU with the
  1948.         OUI of interest.
  1949.  
  1950.    2.   A group Network address Mask of FF-FF-FF-FF-FF-FF-FF-FF-FF-
  1951.         FF-FF-FF-FF-FF-FF-FF-00-00-00-00.
  1952.  
  1953.    3.   A Paired SNPA Address of 00-00-00-00-00-00-00-00-00-
  1954.         00-00-00-00-FF-FF-FF-FF-FF-FF-00.
  1955.  
  1956. 6.12.10 End System Group Hello (ESGH) PDU
  1957.  
  1958.    The ESGH PDU has the format shown in figure 2:
  1959.  
  1960.  
  1961.  
  1962. Marlow                                                         [Page 35]
  1963.  
  1964. RFC 1768                   CLNP Multicasting                  March 1995
  1965.  
  1966.  
  1967.                                                               Octet
  1968.         ,----------------------------------------------------,
  1969.         |          Network Layer Protocol Identifier         |  1
  1970.         |----------------------------------------------------|
  1971.         |                 Length Indicator                   |  2
  1972.         |----------------------------------------------------|
  1973.         |           Version/Protocol ID Extension            |  3
  1974.         |----------------------------------------------------|
  1975.         |               reserved (must be zero)              |  4
  1976.         |----------------------------------------------------|
  1977.         | 0 | 0 | 0 |  Type (00101 = ESGH)                   |  2
  1978.         |----------------------------------------------------|
  1979.         |                    Holding Time                    | 6,7
  1980.         |----------------------------------------------------|
  1981.         |                      Checksum                      | 8,9
  1982.         |----------------------------------------------------|
  1983.         |          Number of Group Address Pairs             |  10
  1984.         |----------------------------------------------------|
  1985.         |   Group Network Address Length Indicator (GNAL)    |  11
  1986.         |----------------------------------------------------|
  1987.         |                                                    |  12
  1988.         :            Group Network Address (GNA)             :
  1989.         |                                                    |
  1990.         |----------------------------------------------------|
  1991.         |    Paired SNPA Address Length Indicator (PSAL)     |
  1992.         |----------------------------------------------------|
  1993.         |                                                    |
  1994.         :             Paired SNPA Address (PSA)              :
  1995.         |                                                    |
  1996.         |----------------------------------------------------|
  1997.         |                        GNAL                        |
  1998.         |----------------------------------------------------|
  1999.         |                                                    |
  2000.         :                        GNA                         |
  2001.         |                                                    |
  2002.         |----------------------------------------------------|
  2003.         |                        PSAL                        |
  2004.         |----------------------------------------------------|
  2005.         |                                                    |
  2006.         :                        PSA                         :
  2007.         |                                                    | m-1
  2008.         |----------------------------------------------------|
  2009.         |                                                    |  m
  2010.         :                       Options                      :
  2011.         |                                                    | p-1
  2012.         '----------------------------------------------------'
  2013.                       Figure 2 - ESGH PDU Format
  2014.  
  2015.  
  2016.  
  2017.  
  2018. Marlow                                                         [Page 36]
  2019.  
  2020. RFC 1768                   CLNP Multicasting                  March 1995
  2021.  
  2022.  
  2023. 6.12.11 Multicast Address Mapping (MAM) PDU
  2024.  
  2025.    The MAM PDU has the format shown in figure 3:
  2026.  
  2027.                                                               Octet
  2028.         ,----------------------------------------------------,
  2029.         |       Network Layer Protocol Identifier            |  1
  2030.         |----------------------------------------------------|
  2031.         |               Length Indicator                     |  2
  2032.         |----------------------------------------------------|
  2033.         |        Version/Protocol ID Extension               |  3
  2034.         |----------------------------------------------------|
  2035.         |           reserved (must be zero)                  |  4
  2036.         |----------------------------------------------------|
  2037.         | 0 | 0 | 0 |  Type (00111 = MAM)                    |  2
  2038.         |----------------------------------------------------|
  2039.         |                Holding Time                        | 6,7
  2040.         |----------------------------------------------------|
  2041.         |                  Checksum                          | 8,9
  2042.         |----------------------------------------------------|
  2043.         |          Number of Group Address Pairs             |  10
  2044.         |----------------------------------------------------|
  2045.         |  Group Network Address Length Indicator (GNAL)     |  11
  2046.         |----------------------------------------------------|
  2047.         |                                                    |  12
  2048.         :          Group Network Address (GNA)               :
  2049.         |                                                    |
  2050.         |----------------------------------------------------|
  2051.         |     Paired SNPA Address Length Indicator (PSAL)    |
  2052.         |----------------------------------------------------|
  2053.         |                                                    |
  2054.         :              Paired SNPA Address (PSA)             :
  2055.         |                                                    |
  2056.         |----------------------------------------------------|
  2057.         |                       GNAL                         |
  2058.         |----------------------------------------------------|
  2059.         |                                                    |
  2060.         :                       GNA                          :
  2061.         |                                                    |
  2062.         |----------------------------------------------------|
  2063.         |                       PSAL                         |
  2064.         |----------------------------------------------------|
  2065.         |                                                    |
  2066.         :                       PSA                          :
  2067.         |                                                    | m-1
  2068.  
  2069.  
  2070.  
  2071.  
  2072.  
  2073.  
  2074. Marlow                                                         [Page 37]
  2075.  
  2076. RFC 1768                   CLNP Multicasting                  March 1995
  2077.  
  2078.  
  2079.         |----------------------------------------------------|
  2080.         |                                                    |  m
  2081.         :                      Options                       :
  2082.         |                                                    | p-1
  2083.         '----------------------------------------------------'
  2084.                      Figure 3 - MAM PDU Format
  2085.  
  2086. 6.13    Conformance
  2087.  
  2088.    All of the extensions provided to the functions to support multicast
  2089.    capability are optional. For an End System or Intermediate System
  2090.    which is not multicast capable these extensions are not applicable. A
  2091.    Network entity may choose to be multicast capable, a multicast
  2092.    capable Network entity is required to support both multicast
  2093.    announcement information and multicast address mapping information.
  2094.  
  2095.    An implementation claiming conformance as a multicast capable End
  2096.    System shall meet all of the requirements for an End System which is
  2097.    not multicast capable and shall support multicast announcement
  2098.    information and shall implement the functions marked as Mandatory (M)
  2099.    in column 4 of table 3. A multicast capable End System implementation
  2100.    shall also support multicast address mapping information and shall
  2101.    implement the functions marked as Mandatory (M) in column 5 of table
  2102.    3.
  2103.  
  2104.    An implementation claiming conformance as a multicast capable
  2105.    Intermediate System shall meet all of the requirements for an
  2106.    Intermediate System which is not multicast capable and shall support
  2107.    multicast announcement information and shall implement the functions
  2108.    marked as Mandatory (M) in column 6 of table 3. A multicast capable
  2109.    Intermediate System implementation shall also support multicast
  2110.    address mapping information and shall implement the functions marked
  2111.    as Mandatory (M) in column 7 of table 3.
  2112.  
  2113.  
  2114.  
  2115.  
  2116.  
  2117.  
  2118.  
  2119.  
  2120.  
  2121.  
  2122.  
  2123.  
  2124.  
  2125.  
  2126.  
  2127.  
  2128.  
  2129.  
  2130. Marlow                                                         [Page 38]
  2131.  
  2132. RFC 1768                   CLNP Multicasting                  March 1995
  2133.  
  2134.  
  2135.      Table 3 - Static Conformance Requirements for Multicast Capable
  2136.      Network Entities
  2137.                                                            ES      IS
  2138.                                                Clause    --------------
  2139.      Label     Function                       Reference  AI  MI  AI  MI
  2140.      ------------------------------------------------------------------
  2141.      RpMAn     Report Multicast Announcement     6.7.1    M   -   -   -
  2142.      RcMAn     Record Multicast Announcement     6.7.2.1  -   -   M   -
  2143.      RcDamp    Record Damping                    6.7.2.2  O   -   -   -
  2144.      FlMAn     Flush Old Multicast Announcement  6.7.3    O   -   M   -
  2145.  
  2146.      RpMAdMa   Report Multicast Address Mapping  6.8.1    -   -   -   M
  2147.      MATGn       ESMAT Generation                6.8.1    -   -   -   M
  2148.      RcMAdMa   Record Multicast Address Mapping  6.8.2    -   M   -   -
  2149.      MATPr       ESMAT Processing                6.8.2    -   M   -   -
  2150.      FlMAdMa   Flush Old Multicast Address Map   6.8.3    -   M   -   -
  2151.  
  2152.      PSAdSel   Paired SNPA Address Selection     6.9.1    -   M   -   -
  2153.      ExtForw   Extensions to CLNP Route Function 6.10     -   M   -   -
  2154.      OSuForw   Originating Subnetwork Forwarding 6.11     -   -   -   M
  2155.  
  2156.      Key:
  2157.      AI = Multicast Announcement information supported
  2158.      MI = Multicast Address Mapping information supported
  2159.  
  2160.      M = Mandatory;  O = Optional;  - = not applicable
  2161.  
  2162. 7.      Security Considerations
  2163.  
  2164.    Security issues are not discussed in this memo.
  2165.  
  2166.  
  2167.  
  2168.  
  2169.  
  2170.  
  2171.  
  2172.  
  2173.  
  2174.  
  2175.  
  2176.  
  2177.  
  2178.  
  2179.  
  2180.  
  2181.  
  2182.  
  2183.  
  2184.  
  2185.  
  2186. Marlow                                                         [Page 39]
  2187.  
  2188. RFC 1768                   CLNP Multicasting                  March 1995
  2189.  
  2190.  
  2191. Appendix A.  Differences with RFC 1112
  2192.  
  2193.    This appendix is intended to identify differences between the
  2194.    mechanisms defined for CLNP Multicast in this specification and those
  2195.    for IP multicast defined in RFC 1112. The work on CLNP Multicast
  2196.    followed the work on IP multicast and was explicitly aimed at
  2197.    bringing the capabilities described in RFC 1112 into a CLNP context.
  2198.    This appendix is intended to provide some background information on
  2199.    the difference; however, it is not intended to justify the mechanisms
  2200.    selected for CLNP multicast use.
  2201.  
  2202.    Static/Dynamic Address Binding of Multicast Datagrams
  2203.  
  2204.    IP multicast utilizes a static binding of Class D IP addresses to a
  2205.    specific range of IEEE 802 48 bit group addresses. The IEEE 802
  2206.    address range that is used is within the address range that IEEE 802
  2207.    allocates for "Global" administration and this block of addresses is
  2208.    under the control of the Internet Assigned Numbers Authority (IANA)
  2209.    which in turn has allocated this block of addresses for use by IP
  2210.    multicast.  This scheme is very simple and efficient. Given the use
  2211.    of a 32 bit IP address, the lower 23 bits of the Class D address are
  2212.    mapped into the lower 23 bits of a 48 bit IEEE 802 address where the
  2213.    upper 25 bits are fixed.  Static binding of this form is global in
  2214.    scope (all members of a group use the same IEEE 802 address on all
  2215.    subnets (at least all that use IEEE 802 addressing).
  2216.  
  2217.    CLNP multicast uses a dynamic binding of a group Network address (up
  2218.    to 20 bytes) to any subnetwork address. In cases where no multicast
  2219.    capable Intermediate Systems are attached to a subnetwork then a
  2220.    binding using preconfigured information or the "All Multicast Capable
  2221.    End Systems" subnetwork addresses is used. The large GNA provides the
  2222.    room to contain a full 48 bit IEEE 802 address if desired.  Mask
  2223.    capabilities are optionally provided which allow a multicast capable
  2224.    Intermediate System to specify a "static" binding for a particular
  2225.    subnetwork. One of the major purposes of providing a dynamic binding
  2226.    is to customize a host's subnetwork address usage to the capabilities
  2227.    of the attached systems.  There is considerable differences in the
  2228.    numbers of group subnetwork addresses that a system can recognize
  2229.    using hardware hooks built into the integrated circuits used. For
  2230.    example the number of addresses that can be recognized by hardware
  2231.    may differ by an attached system depending upon the interface it uses
  2232.    (e.g., Ethernet interface and FDDI within the same system may have
  2233.    quite different capabilities).  Dynamic binding of this form is local
  2234.    in scope (members of a group may use different subnetwork addresses
  2235.    (e.g., IEEE 802 addresses) on different subnets).
  2236.  
  2237.  
  2238.  
  2239.  
  2240.  
  2241.  
  2242. Marlow                                                         [Page 40]
  2243.  
  2244. RFC 1768                   CLNP Multicasting                  March 1995
  2245.  
  2246.  
  2247.    Originating of Multicast Datagrams
  2248.  
  2249.    IP multicast originates multicast datagrams directly, where the host
  2250.    originating a datagram sends it with the group Subnetwork address as
  2251.    its destination. Hosts attached to the network where the datagram is
  2252.    originated receive the datagram directly.
  2253.  
  2254.    CLNP multicast originates multicast datagrams directly using the
  2255.    group's subnetwork address as its destination when multicast address
  2256.    mapping information is available.  This case occurs when a multicast
  2257.    capable Intermediate System is attached to the subnetwork and a host
  2258.    on the subnetwork is announcing an interest in multicast packets
  2259.    identified by a particular group Network address.  The Active
  2260.    Multicast IS may use MAM PDU mask parameters to provide multicast
  2261.    address mapping information for a large number of group Network
  2262.    addresses. When there is no multicast address mapping information for
  2263.    the particular group Network address on a subnetwork with a multicast
  2264.    capable IS attached to it, hosts originate packets using such
  2265.    addresses sends to the "All Multicast Capable Intermediate Systems"
  2266.    SNPA address.  This case occurs when there are no receivers of such
  2267.    multicast packets on the originating subnetwork.  When a multicast
  2268.    capable Intermediate System is not attached to a subnetwork, the End
  2269.    System may utilize either preconfigured information (which might be a
  2270.    direct mapping from a portion of the group Network address) or use
  2271.    the "All Multicast Capable End Systems" address.
  2272.  
  2273.    Address Binding of Control Packets
  2274.  
  2275.    IP multicast sends the control packets related to the IGMP protocol
  2276.    on the same subnetwork address that is used by the multicast data
  2277.    traffic.
  2278.  
  2279.    CLNP multicast sends the control packets related to the ES-IS
  2280.    protocol extensions on specific group subnetwork addresses (i.e.,
  2281.    "All Multicast Capable End Systems" and "All Multicast Announcements"
  2282.    addresses).
  2283.  
  2284.    Router Requirements for relaying Multicast Datagrams
  2285.  
  2286.    IP multicast requires that a multicast router run in "promiscuous"
  2287.    mode where it must receive all multicast datagrams originated on a
  2288.    subnetwork regardless of the destination. This is a result of the
  2289.    choices selected in the "Originating of Multicast Datagrams" and
  2290.    "Address Binding of Control Packets" discussed above.
  2291.  
  2292.    CLNP multicast allows a multicast router to limit multicast packet
  2293.    reception to only those datagrams sent to the SNPA addresses where
  2294.    there is current multicast address mapping information or to the "All
  2295.  
  2296.  
  2297.  
  2298. Marlow                                                         [Page 41]
  2299.  
  2300. RFC 1768                   CLNP Multicasting                  March 1995
  2301.  
  2302.  
  2303.    Multicast Capable Intermediate Systems" address.  The intention is to
  2304.    allow the multicast routers to be in control of the SNPA addresses
  2305.    for multicast packets that they need to receive.  This is a result of
  2306.    the choices selected in the "Originating of Multicast Datagrams" and
  2307.    "Address Binding of Control Packets" discussed above.
  2308.  
  2309.    Aggregation of Control Information
  2310.  
  2311.    In IP multicast, a host is required to withhold an announcement
  2312.    report upon hearing another host reporting a similar interest in a
  2313.    particular Class D address on a particular subnetwork. This is an
  2314.    option for CLNP multicast (upon hearing interest in a particular
  2315.    group Network address on a particular subnetwork). Such reports are
  2316.    not combined in IP multicast while CLNP multicast supports providing
  2317.    multiple announcements (and address mappings) within a single packet.
  2318.    A mask feature for address mappings supports identifying mappings for
  2319.    a range of group Network addresses within a single control packet.
  2320.  
  2321.    Datagram Scope Control
  2322.  
  2323.    IP multicast supports the use of the IP Hop Count as a means to
  2324.    support scope control. While not documented in RFC 1112, a technique
  2325.    is also being used to use bits within the Class D address to identify
  2326.    whether a datagram has single subnetwork, "campus" or global scope.
  2327.  
  2328.    CLNP has considerable scope control functionality. While the PDU
  2329.    Lifetime field can be employed in a similar way to the IP Hop Count,
  2330.    two additional options are available. The Radius scope control
  2331.    provides a mechanism for "administratively" setting distance values
  2332.    and de-couples the multicast scope control from the PDU lifetime
  2333.    function. More importantly, the Prefix based scope control appears to
  2334.    provide considerable and flexible functionality that can adjust to
  2335.    situations where a known, hierarchical unicast addressing structure
  2336.    exists.
  2337.  
  2338.    Marking of Multicast Datagrams
  2339.  
  2340.    IP multicast marks a multicast PDU via the use of an IP Class D
  2341.    address as its destination address parameter. CLNP multicast marks
  2342.    both the PDU (a different PDU type) and the destination address
  2343.    (i.e., group Network address) parameter.
  2344.  
  2345.    Unicast Addressing Differences
  2346.  
  2347.    An IP address identifies a specific host interface while a CLNP
  2348.    individual Network address (i.e., NSAP address) identifies a
  2349.    particular Network entity. This difference has lead to a difference
  2350.    with RFC 1112.  IP multicast requires a host which is attached to
  2351.  
  2352.  
  2353.  
  2354. Marlow                                                         [Page 42]
  2355.  
  2356. RFC 1768                   CLNP Multicasting                  March 1995
  2357.  
  2358.  
  2359.    more than one subnetwork to originate a multicast packet on only one
  2360.    subnetwork.  CLNP multicast requires a host which is attached to more
  2361.    than one subnetwork to originate a multicast packet on every
  2362.    subnetwork that the ISO ES-IS Configuration function is reporting the
  2363.    NSAP address contained in the source address parameter of the
  2364.    multicast PDU.
  2365.  
  2366.    Error Reports
  2367.  
  2368.    Error reports sent in response to receiving a multicast PDU are not
  2369.    permitted in IP multicast while they are permitted in CLNP multicast.
  2370.  
  2371.    Source Routing
  2372.  
  2373.    Source routing of multicast PDUs are permitted in IP multicast (but
  2374.    at the present time this is discouraged) while they are not permitted
  2375.    in CLNP multicast.
  2376.  
  2377. Appendix B.  Issues Under Study
  2378.  
  2379.    This appendix is intended to record the current issues (as discussed
  2380.    at the March 1994 TUBA meeting).
  2381.  
  2382.    1. Local versus Global address bindings
  2383.  
  2384.    The extensions to the ES-IS protocol provide a multicast address
  2385.    mapping function which supports dynamically binding a group Network
  2386.    address to a subnetwork address.  Concern has been expressed that
  2387.    this is an unnecessary feature which complicates the job of network
  2388.    administrators without suitable benefit.  A static, global binding of
  2389.    group Network addresses to IEEE 802 subnetwork addresses, as is used
  2390.    by IP multicast has been suggested.
  2391.  
  2392.    The two main reasons that the group Network address to subnetwork
  2393.    (IEEE 802) address was made locally configurable were to support
  2394.    multicast on subnets with hosts having a mixture of capabilities (as
  2395.    to how many multicast subnetwork addresses a host could register to
  2396.    receive at a time) and to support multicast on subnets that do not
  2397.    use 48 bit IEEE 802 addresses.  Thus it was felt that this should be
  2398.    done per subnetwork versus globally.  Even multi-homed hosts with
  2399.    subnets that use 802 addresses may have varying capabilities (looking
  2400.    at typical Ethernet, FDDI and 802.5 implementations).
  2401.  
  2402.    One possible solution is to recommend a direct mapping in any
  2403.    Internet use of CLNP multicast on subnets which use IEEE 802
  2404.    addressing.  This could be a default for all Internet hosts.  A
  2405.    policy would be needed to identify the Internet's group Network
  2406.    address format.  Given such a mapping the only operational overhead
  2407.  
  2408.  
  2409.  
  2410. Marlow                                                         [Page 43]
  2411.  
  2412. RFC 1768                   CLNP Multicasting                  March 1995
  2413.  
  2414.  
  2415.    that would occur is that in the presence of a mapping server (the
  2416.    Active Multicast IS), which was supporting this mapping, a MAM PDU
  2417.    would periodically be sent with a Group Network Address Mask which
  2418.    would identify the direct mapping.
  2419.  
  2420.    2.  "Real Time" Scope Control Features
  2421.  
  2422.    The scope control features are provided via optional parameters.  Use
  2423.    of multicast transfer of audio and video streams may require scope
  2424.    control mechanisms which operate very quickly.
  2425.  
  2426.    One possible solution is to embed scope control mechanisms into the
  2427.    group Network address itself.  For example, a group Network address
  2428.    using the "Local" AFI is automatically limited to not cross inter-
  2429.    domain borders.  Further, more flexible, address formats may be
  2430.    developed.
  2431.  
  2432. References
  2433.  
  2434.    [Deering91] Deering, S., "Multicast Routing in a Datagram
  2435.    Internetwork", PhD thesis, Electrical Engineering Dept., Stanford
  2436.    University, December 1991.
  2437.  
  2438.    [RFC1112] Deering, S., "Host Extensions for IP Multicasting",
  2439.    STD 5, RFC 1112, Stanford University, August 1989.
  2440.  
  2441.    [RFC1237] Colella, R., Gardner, E., and R. Callon, "Guidelines for OSI
  2442.    NSAP Allocation in the Internet", RFC 1237, NIST, Mitre, DEC, July
  2443.    1991.
  2444.  
  2445.    [CLNP] Protocol for providing the connectionless-mode network service,
  2446.    International Standard 8473-1, Second Edition, ISO/IEC JTC 1,
  2447.    Switzerland 1994.  (Available via FTP from
  2448.    merit.edu:pub/iso/iso8473part1.ps).
  2449.  
  2450.    [ES-IS] End system to Intermediate system routing exchange protocol
  2451.    for use in conjunction with the Protocol for providing the
  2452.    connectionless-mode network service, International Standard 9542,
  2453.    ISO/IEC JTC 1, Switzerland 1987.  (Available via FTP from
  2454.    merit.edu:pub/iso/iso9542.ps).
  2455.  
  2456.    [MULT-AMDS]: Amendments to ISO standards to support CLNP multicast
  2457.    extensions:
  2458.  
  2459.    ISO 8348 AM5 Amendment to the Network Service to support Group Network
  2460.    Addressing. International Standard ISO 8348 Amendment 5, ISO/IEC JTC
  2461.    1, Switzerland 1994.
  2462.  
  2463.  
  2464.  
  2465.  
  2466. Marlow                                                         [Page 44]
  2467.  
  2468. RFC 1768                   CLNP Multicasting                  March 1995
  2469.  
  2470.  
  2471.    ISO 8473-1 DAM1 - Draft Amendment to the Second Edition of the
  2472.    Protocol for providing the connectionless-mode network service [CLNP],
  2473.    Multicast Extension, 1993.
  2474.  
  2475.    ISO 9542 DAM2 - Draft Amendment to the ES-IS [ES-IS] protocol,
  2476.    Addition of connectionless- mode multicast capability, 1993.
  2477.  
  2478. Author's Address
  2479.  
  2480.    Dave Marlow
  2481.    Code B35
  2482.    NSWC-DD
  2483.    Dahlgren, VA. 22448
  2484.  
  2485.    Phone: (703) 663-1675
  2486.    EMail: dmarlow@relay.nswc.navy.mil
  2487.  
  2488.  
  2489.  
  2490.  
  2491.  
  2492.  
  2493.  
  2494.  
  2495.  
  2496.  
  2497.  
  2498.  
  2499.  
  2500.  
  2501.  
  2502.  
  2503.  
  2504.  
  2505.  
  2506.  
  2507.  
  2508.  
  2509.  
  2510.  
  2511.  
  2512.  
  2513.  
  2514.  
  2515.  
  2516.  
  2517.  
  2518.  
  2519.  
  2520.  
  2521.  
  2522. Marlow                                                         [Page 45]
  2523.  
  2524.